SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **DESCRIPTION**

The 4250 Group is a 4-bit single-chip microcomputer designed with CMOS technology. Its CPU is that of the 720 series using a simple instruction set. The computer is equipped with one 8-bit timer which has a reload register and the interrupt function. The various microcomputers in the 4250 Group include variations of the built-in memory type as shown in the table below.

### **FEATURES**

- Supply voltage
   4.5 V to 5.5 V (at 4.0 MHz system clock frequency)
   2.5 V to 5.5 V (at 1.0 MHz system clock frequency)
   2.2 V to 5.5 V (at 1.0 MHz system clock frequency: only for Mask ROM version)

- CR oscillation circuit (Capacitor and Resistor connected externally)
- Logic operation instruction
- · RAM back-up function
- · Key-on wakeup function (ports G and S, INT pin)

### **APPLICATION**

Electric household appliances, consumer electronics products (mouse, etc.)

| Product          | ROM (PROM) size<br>(X 9 bits) | RAM size<br>(X 4 bits) | Package | ROM type      |
|------------------|-------------------------------|------------------------|---------|---------------|
| M34250M2-XXXFP   | 2048 words                    | 64 words               | 20P2N-A | Mask ROM      |
| M34250E2-XXXFP * | 2048 words                    | 64 words               | 20P2N-A | One Time PROM |

<sup>\*:</sup> Shipped after writing (shipped in blank: M34250E2FP)

# PIN CONFIGURATION (TOP VIEW) M34250M2-XXXFP VDD 1 20 $\longrightarrow$ D0 VSS 2 19 $\longrightarrow$ D1 XIN $\longrightarrow$ 3 18 $\longrightarrow$ D2/C XOUT $\longleftarrow$ 4 17 $\longrightarrow$ D3/K CNVss 5 RESET $\longrightarrow$ 6 $\longrightarrow$ 6 $\longrightarrow$ S0 RESET $\longrightarrow$ 6 $\longrightarrow$ 7 $\longrightarrow$ 15 $\longrightarrow$ S1 F0 $\longrightarrow$ 7 $\longrightarrow$ 7 $\longrightarrow$ 14 $\longrightarrow$ S2 F1 $\longrightarrow$ 8 $\longrightarrow$ 8 $\longrightarrow$ 13 $\longrightarrow$ S3 G0/INT $\longrightarrow$ 9 $\longrightarrow$ 12 $\longrightarrow$ G2 Outline 20P2N-A



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **PERFORMANCE OVERVIEW**

| Pa                                 | arameter                       |              | Function                                                                                                          |  |  |
|------------------------------------|--------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------|--|--|
| Number of bas                      | ic instruc                     | tions        | 70                                                                                                                |  |  |
| Minimum instruction execution time |                                | ecution time | 1.0 $\mu$ s (at 4.0 MHz system clock frequency) (Refer to the electrical characteristics because                  |  |  |
|                                    |                                |              | the minimum instruction execution time depends on the supply voltage.)                                            |  |  |
| Memory sizes                       | ROM                            | M34250M2/    | 048 words X 9 bits                                                                                                |  |  |
|                                    | RAM                            | E2           | 64 words X 4 bits                                                                                                 |  |  |
| Input/Output                       | D0-D3                          | I/O          | Four independent I/O ports; ports D <sub>2</sub> and D <sub>3</sub> are also used as ports C and K, respectively. |  |  |
| ports                              | S0-S3                          | I/O          | 4-bit I/O port                                                                                                    |  |  |
|                                    | С                              | I/O          | 1-bit I/O port; port C is also used as port D2.                                                                   |  |  |
|                                    | K                              | I/O          | 1-bit I/O port; port K is also used as port D <sub>3</sub> .                                                      |  |  |
|                                    | F0, F1                         | I/O          | 2-bit I/O port                                                                                                    |  |  |
|                                    | G <sub>0</sub> –G <sub>3</sub> | I/O          | 4-bit I/O port; ports G₀ and G₁ are also used as pins INT and Tou⊤.                                               |  |  |
| INT Input Tout Output              |                                | Input        | Interrupt input; INT pin is also used as port Go.                                                                 |  |  |
|                                    |                                | Output       | Timer output; Tou⊤ pin is also used as port G₁.                                                                   |  |  |
| Timer                              | Timer 1                        |              | 8-bit timer with a reload register                                                                                |  |  |
| Interrupt                          | Sources                        | ;            | 2 (one for external and one for timer)                                                                            |  |  |
|                                    | Nesting                        |              | 1 level                                                                                                           |  |  |
| Oscillation circ                   | uit                            |              | CR oscillation circuit (a capacitor and a resistor connected externally)                                          |  |  |
|                                    |                                |              | Frequency error: ±17 %                                                                                            |  |  |
|                                    |                                |              | $(VDD = 5 V \pm 10 \%, VDD = 3 V \pm 10 \%, the error of the external capacitor and resistor excluded)$           |  |  |
| Subroutine nes                     | sting                          |              | 4 levels                                                                                                          |  |  |
| Device structu                     | re                             |              | CMOS silicon gate                                                                                                 |  |  |
| Package                            |                                |              | 20-pin plastic molded SOP (20P2N-A)                                                                               |  |  |
| Operating tem                      | perature                       | range        | −20 °C to 85 °C                                                                                                   |  |  |
| Supply voltage                     | ;                              |              | 2.2 V to 5.5 V (Refer to the electrical characteristics because the supply voltage depends or                     |  |  |
|                                    |                                |              | the system clock frequency.)                                                                                      |  |  |
| Power                              | Active m                       | node         | 1.5 mA                                                                                                            |  |  |
| dissipation                        |                                |              | (at 4.0 MHz system clock frequency, VDD = 5 V, output transistors in the cut-off state)                           |  |  |
| (typical value)                    | RAM ba                         | ck-up mode   | 0.1 $\mu$ A (at room temperature, VDD = 5 V, output transistors in the cut-off state)                             |  |  |



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **PIN DESCRIPTION**

| Pin    | Name                | Input/Output | Function                                                                                                                                                           |  |  |
|--------|---------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| VDD    | Power supply        | _            | Connected to a plus power supply.                                                                                                                                  |  |  |
| Vss    | Ground              | _            | Connected to a 0 V power supply.                                                                                                                                   |  |  |
| CNVss  | CNVss               | _            | Connect CNVss to Vss and apply "L" (0V) to CNVss certainly.                                                                                                        |  |  |
| RESET  | Reset input         | Input        | Reset pulse input pin                                                                                                                                              |  |  |
| XIN    | System clock input  | Input        | I/O pins of the system clock generating circuit. Connect pins XIN and XOUT directly.                                                                               |  |  |
| Хоит   | System clock output | Output       | Then, pull up XIN pin through a resistor and pull down XOUT pin through a capacitor.                                                                               |  |  |
| F0, F1 | I/O port F          | I/O          | 2-bit I/O port; for input use, set the latch of the specified bit to "1." The output structure is N-channel open-drain.                                            |  |  |
| G0–G3  | I/O port G          | I/O          | 4-bit I/O port. For input use, set the latch of the specified bit to "1." The output structure is N-channel open-drain. Every pin of the ports has a key-on wakeup |  |  |
|        |                     |              | function and a pull-up function. Both functions can be switched by software.                                                                                       |  |  |
|        |                     |              | Ports G₀ and G₁ are also used as pins INT and Tout, respectively.                                                                                                  |  |  |
| S0-S3  | I/O port S          | I/O          | 4-bit I/O port. For input use, set the latch of the specified bit to "1." The output                                                                               |  |  |
|        |                     |              | structure is N-channel open-drain. Every pin of the ports has a key-on wakeup                                                                                      |  |  |
|        |                     |              | function which can be switched by software. Also, it is used to perform the logic                                                                                  |  |  |
|        |                     |              | operation using register A.                                                                                                                                        |  |  |
| D0-D3  | I/O port D          | I/O          | Each pin of port D has an independent 1-bit wide I/O function. For input use, set                                                                                  |  |  |
|        |                     |              | the latch of the specified bit to "1." The output structure is N-channel open-drain.                                                                               |  |  |
|        |                     |              | Ports D <sub>2</sub> and D <sub>3</sub> are also used as ports C and K, respectively.                                                                              |  |  |
| С      | I/O port C          | I/O          | 1-bit I/O port. For input use, set the latch of the specified bit to "1." The output                                                                               |  |  |
|        |                     |              | structure is N-channel open-drain. Port C has a pull-up function which can be                                                                                      |  |  |
|        |                     |              | switched by software. It is also used as port D <sub>2</sub> .                                                                                                     |  |  |
| K      | I/O port K          | I/O          | 1-bit I/O port. For input use, set the latch of the specified bit to "1." The output                                                                               |  |  |
|        |                     |              | structure is N-channel open-drain. Port K has a pull-up function which can be                                                                                      |  |  |
|        |                     |              | switched by software. It is also used as port D <sub>3</sub> .                                                                                                     |  |  |
| Тоит   | Timer output        | Output       | Tout pin has the function to output the timer 1 underflow signal divided by 2. It is                                                                               |  |  |
|        |                     |              | also used as port G <sub>1</sub> .                                                                                                                                 |  |  |
| INT    | Interrupt input     | Input        | INT pin accepts an external interrupt. It also accepts the input signal to return the                                                                              |  |  |
|        |                     |              | system from the RAM back-up state. It is also used as port Go.                                                                                                     |  |  |



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **MULTIFUNCTION**

| Pin            | Multifunction | Pin           | Multifunction  |
|----------------|---------------|---------------|----------------|
| G <sub>0</sub> | INT           | INT (Note 2)  | G <sub>0</sub> |
| G1             | Тоит          | Tout (Note 2) | G1             |
| D <sub>2</sub> | С             | C (Note 2)    | D <sub>2</sub> |
| D <sub>3</sub> | K             | K (Note 2)    | D3             |

Notes 1: Pins except above have just single function.

2: The I/O of ports D₂, D₃ and G₀, and the input of port G₁ can be used even when ports C and K and pins INT and Tou⊤ are selected.

### **CONNECTIONS OF UNUSED PINS**

| Pin             | Connection                           | Pin                                  | Connection                           |
|-----------------|--------------------------------------|--------------------------------------|--------------------------------------|
| Fo, F1          | Connect to Vss pin.                  | Do, D1                               | Connect to Vss pin.                  |
| Go/INT, G1/Tout | Open or connect to Vss pin. (Note 1) | D <sub>2</sub> /C, D <sub>3</sub> /K | Open or connect to Vss pin. (Note 3) |
| G2, G3          |                                      |                                      |                                      |
| S0-S3           | Connect to Vss pin. (Note 2)         |                                      |                                      |

- Notes 1: When pins G<sub>0</sub>/INT, G<sub>1</sub>/T<sub>0</sub>UT, G<sub>2</sub> and G<sub>3</sub> are connected to Vss pin, turn off their pull-up transistors (Pull-up control register PU0="X02") and also invalidate the key-on wakeup functions of pins G<sub>1</sub>/T<sub>0</sub>UT, G<sub>2</sub> and G<sub>3</sub> (Key-on wakeup contorl register K0="XX0X2") by software. When the POF instruction is executed while these pins are connected to Vss and the key-on wakeup functions are left valid, the system returns from RAM back-up state by recognizing the return condition immediately after going into the RAM back-up state. When these pins are open, turn on their pull-up transistors (Pull-up control register PU0="X12") by software.
  - 2: When ports S<sub>0</sub>–S<sub>3</sub> are connected to Vss pin, invalidate the key-on wakeup functions (Key-on wakeup contorl register K0="XXX0<sub>2</sub>") by software. When the POF instruction is executed while these pins are connected to Vss and the key-on wakeup functions are left valid, the system returns from RAM back-up state by recognizing the return condition immediately after going into the RAM back-up state.
  - 3: When ports D<sub>2</sub>/C and D<sub>3</sub>/K are connected to Vss pin, turn off their pull-up transistors (register PU0="0X<sub>2</sub>") by software. When these pins are open, turn on their pull-up transistors (register PU0="1X<sub>2</sub>") by software.

(Note when connecting to Vss and VDD)

• Connect the unused pins to Vss or Vpp at the shortest distance and use the thick wire against noise.



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### PORT FUNCTION

| Port   | Pin                             | Input/ | Output structure     | Control | Control      | Control   | Remark                    |
|--------|---------------------------------|--------|----------------------|---------|--------------|-----------|---------------------------|
|        |                                 | Output | Output off dotailo   | bits    | instructions | registers | rtomant                   |
| Port D | D <sub>0</sub> , D <sub>1</sub> | I/O    | N-channel open-drain | 1       | SD           |           |                           |
|        | D <sub>2</sub> /C               | (4)    |                      |         | RD           | PU0       | Pull-up function          |
|        | D <sub>3</sub> /K               |        |                      |         | SZD          |           | (programmable)            |
|        |                                 |        |                      |         | CLD          |           |                           |
|        |                                 |        |                      |         | SCP          |           |                           |
|        |                                 |        |                      |         | RCP          |           |                           |
|        |                                 |        |                      |         | SNZCP        |           |                           |
|        |                                 |        |                      |         | OKA          |           |                           |
|        |                                 |        |                      |         | IAK          |           |                           |
| Port S | S0-S3                           | I/O    | N-channel open-drain | 4       | OSA          | K0        | Logic operation function  |
|        |                                 | (4)    |                      |         | IAS          | LO        | (programmable)            |
|        |                                 |        |                      |         | LGOP         |           | Key-on wakeup functions   |
|        |                                 |        |                      |         |              |           | (programmable)            |
| Port G | G <sub>0</sub> /INT             | I/O    | N-channel open-drain | 4       | OGA          | PU0, K0   | Pull-up functions         |
|        |                                 | (4)    |                      |         | IAG          |           | Key-on wakeup functions   |
|        |                                 |        |                      |         |              |           | (only pull-up function is |
|        |                                 |        |                      |         |              |           | programmable)             |
|        | G <sub>1</sub> /Tout            |        |                      |         |              | PU0, K0   | Pull-up functions         |
|        |                                 |        |                      |         |              | V1        | (programmable)            |
|        | G2, G3                          |        |                      |         |              | PU0, K0   | Key-on wakeup functions   |
|        |                                 |        |                      |         |              |           | (programmable)            |
| Port F | F0, F1                          | I/O    | N-channel open-drain | 2       | OFA          |           |                           |
| 1      |                                 | (2)    |                      |         | IAF          |           |                           |

### **DEFINITION OF CLOCK AND CYCLE**

• System clock

This is the source clock input to the XIN pin. Connect pins XIN and XOUT directly. Then, pull up XIN pin through a resistor and pull down XOUT pin through a capacitor.

- · Instruction clock
  - The instruction clock is a signal derived by dividing the system clock by 4, and is the basic clock for controlling this product.
- · Machine cycle

One machine cycle is the time required to execute the minimum instruction (one-cycle instruction). The machine cycle is equivalent to the instruction clock cycle.



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### I/O PORT

### (1) Port D (D0-D3)

Each pin of port D has an independent 1-bit wide I/O function. Each pin has an output latch. For input/output of ports  $D_0$ – $D_3$ , select one of port D with the register Y of data pointer first. For input use, set the latch of the specified bit to "1." All port D output latches can be set to "1" with the CLD instruction. The output structure is the N-channel open-drain. Ports  $D_2$  and  $D_3$  are also used as ports C and K, respectively. Accordingly, when port  $D_2/C$  is used as port  $D_2$ , set the port C output latch to "1." When port  $D_3/K$  is used as port  $D_3$ , set the port K output latch to "1."

### (2) Port C

1-bit I/O port.

Port C output latch can be set to "1" with the SCP instruction. Port C output latch can be cleared to "0" with the RCP instruction. Port C input level can be examined by executing the skip (SNZCP) instruction. For input use, set the latch of the specified bit to "1." The output structure is the N-channel open-drain. The pull-up transistor of port C is turned on when the bit 1 of register PU0 is set to "1" by software. Port C is also used as port D2. Accordingly, when port D2/C is used as port C, set the port D2 output latch to "1."

### (3) Port K

1-bit I/O port.

For input use, set the latch of the specified bit to "1." The output structure is the N-channel open-drain. The pull-up transistor of port K is turned on when the bit 1 of register PU0 is set to "1" by software. Port K is also used as port D<sub>3</sub>. Accordingly, when port D<sub>3</sub>/K is used as port K, set the port D<sub>3</sub> output latch to "1."

### (4) Port G (G0-G3)

4-bit I/O port.

For input use, set the latch of the specified bit to "1." The output structure is the N-channel open-drain. The pull-up transistor of port G is turned on when the bit 0 of register PU0 is set to "1" by software. Ports  $G_0$  and  $G_1$  are also used as INT pin and  $T_{OUT}$  pin, respectively.

### Pull-up control register

| Pull-up control register PU0          |                                      | at reset : 002           |                       | at RAM back-up : state retained |  |
|---------------------------------------|--------------------------------------|--------------------------|-----------------------|---------------------------------|--|
| DI IO.                                | Ports C and K                        | 0 Pull-up transistor C   |                       | )FF                             |  |
| PU01 pull-up transistor control bit   |                                      | 1                        | Pull-up transistor O  | N                               |  |
| DI IO-                                | Ports G <sub>0</sub> –G <sub>3</sub> | 0 Pull-up transistor OFF |                       |                                 |  |
| PU00   pull-up transistor control bit |                                      | 1                        | Pull-up transistor ON |                                 |  |

Note: "W" represents write enabled.



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### (5) Port F (F<sub>0</sub>, F<sub>1</sub>)

2-bit I/O port.

For input use, set the latch of the specified bit to "1." The output structure is the N-channel open-drain.

### (6) Port S (S<sub>0</sub>-S<sub>3</sub>)

4-bit I/O port.

Port S has the logic operation (LGOP) function. For input (logic operation included) use, set the latch of the specified bit to "1." The output structure is the N-channel open-drain. When performing the logic operation, select the logic operation function with the logic operation selection register LO. Set the contents of register LO through register A with the TLOA instruction.

When the LGOP instruction is executed, the logic operation selected with the register LO is performed between the contents of register A and the contents of port S, and its result is stored in register A.

### Logic operation selection register

| Lo              | Logic operation selection register LO   |   | a               | t reset : 002 | at RAM back-up : 002 | W |
|-----------------|-----------------------------------------|---|-----------------|---------------|----------------------|---|
|                 | Logic operation function selection bits |   | LO <sub>0</sub> | Functions     |                      |   |
| LO <sub>1</sub> |                                         |   | 0               | XOR operation |                      |   |
|                 |                                         |   | 1               | OR operation  |                      |   |
| LO <sub>0</sub> | 00                                      | 1 | 0               | AND operation |                      |   |
|                 |                                         |   | 1               | Not available |                      |   |

Note: "W" represents write enabled.



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **PORT BLOCK DIAGRAMS**



### PORT BLOCK DIAGRAMS (CONTINUED)



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

# FUNCTION BLOCK OPERATIONS CPU

### (1) Arithmetic logic unit (ALU)

The arithmetic logic unit ALU performs 4-bit arithmetic such as 4-bit data addition, comparison, and bit manipulation.

### (2) Register A and carry flag

Register A is a 4-bit register used for arithmetic, transfer, exchange, and I/O operation.

Carry flag CY is a 1-bit flag that is set to "1" when there is a carry with the AMC instruction (Figure 1).

It is unchanged with both A n instruction and AM instruction. The value of Ao is stored in carry flag CY with the RAR instruction (Figure 2).

Carry flag CY can be set to "1" with the SC instruction and cleared to "0" with the RC instruction.

### (3) Registers B and E

Register B is a 4-bit register used for temporary storage of 4-bit data, and for 8-bit data transfer together with register A. Register E is an 8-bit register. It can be used for 8-bit data transfer with register B used as the high-order 4 bits and register A as the low-order 4 bits (Figure 3).

### (4) Register D

Register D is a 3-bit register.

It is used to store a 7-bit ROM address together with register A and is used as a pointer within the specified page when the TABP p, BLA p, or BMLA p instruction is executed (Figure 4).



Fig. 1 AMC instruction execution example



Fig. 2 RAR instruction execution example



Fig. 3 Registers A, B and register E



Fig. 4 TABP p instruction execution example



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### (5) Stack registers (SKs) and stack pointer (SP)

Stack registers (SKs) are used to temporarily store the contents of program counter (PC) just before branching until returning to the original routine when;

- branching to an interrupt service routine (referred to as an interrupt service routine).
- · performing a subroutine call, or
- executing the table reference instruction (TABP p).

Stack registers (SKs) are four identical registers, so that subroutines can be nested up to 4 levels. However, one of stack registers is used respectively when using an interrupt service routine and when executing a table reference instruction. Accordingly, be careful not to over the stack when performing these operations together. The contents of registers SKs are destroyed when 4 levels are exceeded.

The register SK nesting level is pointed automatically by 2-bit stack pointer (SP).

Figure 5 shows the stack registers (SKs) structure.

Figure 6 shows the example of operation at subroutine call.

### (6) Interrupt stack register (SDP)

Interrupt stack register (SDP) is a 1-stage register. When an interrupt occurs, this register (SDP) is used to temporarily store the contents of data pointer, carry flag and skip flag just before an interrupt until returning to the original routine.

Unlike the stack registers (SKs), this register (SDP) is not used when executing the subroutine call instruction and the table reference instruction.

### (7) Skip flag

Skip flag controls skip decision for the conditional skip instructions and continuous described skip instructions. When an interrupt occurs, the contents of skip flag is stored automatically in the interrupt stack register (SDP) and the skip condition is retained.



Stack pointer (SP) points "3" at reset or returning from RAM back-up mode. It points "0" by executing the first BM instruction, and the contents of program counter is stored in SKo. When the BM instruction is executed after four stack registers are used ((SP) = 3), (SP) = 0 and the contents of SKo is destroyed.

Fig. 5 Stack registers (SKs) structure



Fig. 6 Example of operation at subroutine call



### SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### (8) Program counter (PC)

Program counter (PC) is used to specify a ROM address (page and address). It determines a sequence in which instructions stored in ROM are read. It is a binary counter that increments the number of instruction bytes each time an instruction is executed. However, the value changes to a specified address when branch instructions, subroutine call instructions, return instructions, or the table reference instruction (TABP p) is executed.

Program counter consists of PC<sub>H</sub> (most significant bit to bit 7) which specifies to a ROM page and PC<sub>L</sub> (bits 6 to 0) which specifies an address within a page. After it reaches the last address (address 127) of a page, it specifies address 0 of the next page (Figure 7).

Make sure that the PC ${\rm H}$  does not exceed after the last page of the built-in ROM.

### (9) Data pointer (DP)

Data pointer (DP) is used to specify a RAM address and consists of registers X and Y. Register X specifies a file and register Y specifies a RAM digit (Figure 8).

Register Y is also used to specify the port D bit position. When using port D, set the port D bit position to register Y certainly and execute the SD, RD, or SZD instruction (Figure 9).



Fig. 7 Program counter (PC) structure



Fig. 8 Data pointer (DP) structure



Fig. 9 SD instruction execution example



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **PROGRAM MEMORY (ROM)**

The program memory is a mask ROM. 1 word of ROM is composed of 9 bits. ROM is separated every 128 words by the unit of page (addresses 0 to 127). Table 1 shows the ROM size and pages. Figure 10 shows the ROM map of M34250M2.

Table 1 ROM size and pages

| Product  | ROM size (X 9 bits) | Pages        |
|----------|---------------------|--------------|
| M34250M2 | 20.40               | 4C (0 to 4E) |
| M34250E2 | 2048 words          | 16 (0 to 15) |

A part of page 1 (addresses 0080<sub>16</sub> to 00FF<sub>16</sub>) is reserved for interrupt addresses (Figure 11). When an interrupt occurs, the address (interrupt address) corresponding to each interrupt is set in the program counter, and the instruction at the interrupt address is executed. When using an interrupt service routine, write the instruction generating the branch to that routine at an interrupt address.

Page 2 (addresses 010016 to 017F16) is the special page for subroutine calls. Subroutines written in this page can be called from any page with the 1-word instruction (BM). Subroutines extending from page 2 to another page can also be called with the BM instruction when it starts on page 2.

ROM pattern (bits 7 to 0) of all addresses can be used as data areas with the TABP p instruction.

### **DATA MEMORY (RAM)**

1 word of RAM is composed of 4 bits, but 1-bit manipulation (with the SB j, RB j, and SZB j instructions) is enabled for the entire memory area. A RAM address is specified by a data pointer. The data pointer consists of registers X and Y. Set a value to the data pointer certainly when executing an instruction to access RAM.

Table 2 shows the RAM size. Figure 12 shows the RAM map.

Table 2 RAM size

| Product  | RAM size                     |
|----------|------------------------------|
| M34250M2 | 64 words V 4 hits (256 hits) |
| M34250E2 | 64 words X 4 bits (256 bits) |



Fig. 10 ROM map of M34250M2



Fig. 11 Page 1 (addresses 008016 to 00FF16) structure



Fig. 12 RAM map



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### INTERRUPT FUNCTION

The interrupt type is a vectored interrupt branching to an individual address (interrupt address) according to each interrupt source. An interrupt occurs when the following 3 conditions are satisfied.

- An interrupt activated condition is satisfied (request flag = "1")
- Interrupt enable bit = "1" (interrupt request occurrence enabled)
- Interrupt enable flag (INTE) = "1" (interrupt enabled)
  Table 3 shows interrupt sources. (Refer to each interrupt request flag for details of activated conditions.)

### (1) Interrupt enable flag (INTE)

The interrupt enable flag (INTE) controls whether the every interrupt enable/disable. Interrupts are enabled when INTE flag is set to "1" with the EI instruction and disabled when INTE flag is cleared to "0" with the DI instruction. When any interrupt occurs, the INTE flag is automatically cleared to "0," so that other interrupts are disabled until the EI instruction is executed.

### (2) Interrupt enable bit (V10, V11)

Use an interrupt enable bit of interrupt control register V1 to select the corresponding interrupt or skip instruction.

Table 4 shows the interrupt request flag, interrupt enable bit and skip instruction.

Table 5 shows the interrupt enable bit function.

### (3) Interrupt request flag

When the activated condition for each interrupt is satisfied, the corresponding interrupt request flag is set to "1." Each interrupt request flag is cleared to "0" when either:

- an interrupt occurs, or
- the next instruction is skipped with a skip instruc-

Each interrupt request flag is set when the activated condition is satisfied even if the interrupt is disabled by the INTE flag or its interrupt enable bit. Once set, the interrupt request flag retains set until a clear condition is satisfied.

Accordingly, an interrupt occurs when the interrupt disable state is released while the interrupt request flag

If more than one interrupt request flag is set when the interrupt disable state is released, the interrupt priority level is as follows shown in Table 3.

### Table 3 Interrupt sources

| Priority | Into we unt in a man | A stirrate di son dition | Interrupt |
|----------|----------------------|--------------------------|-----------|
| level    | Interrupt name       | Activated condition      | address   |
| 1        | External interrupt   | Level change of INT      | Address 0 |
|          |                      | pin                      | in page 1 |
| 2        | Timer 1 interrupt    | Timer 1 underflow        | Address 2 |
|          |                      |                          | in page 1 |

Table 4 Interrupt request flag, interrupt enable bit and skip instruction

| Interrupt name     | Request flag | Enable bit      | Skip instruction |
|--------------------|--------------|-----------------|------------------|
| External interrupt | EXF0         | V10             | SNZ0             |
| Timer 1 interrupt  | T1F          | V1 <sub>1</sub> | SNZ1             |

### Table 5 Interrupt enable bit function

| Interrupt anable bit | Occurrence of     | Ckin instruction |  |
|----------------------|-------------------|------------------|--|
| Interrupt enable bit | interrupt request | Skip instruction |  |
| 1                    | Enabled           | Invalid          |  |
| 0                    | Disabled          | Valid            |  |



### SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### (4) Internal state during an interrupt

The internal state of the microcomputer during an interrupt is as follows (Figure 14).

- Program counter (PC)
   An interrupt address is set in program counter. The address to be executed when returning to the main routine is automatically stored in the stack register (SK).
- Interrupt enable flag (INTE)
   INTE flag is cleared to "0" so that interrupts are disabled.
- Interrupt request flag
   Only the request flag for the current interrupt source is cleared to "0."
- Data pointer, carry flag and skip flag
   The contents of these pointer and flags are stored automatically in the interrupt stack register (SDP).

### (5) Interrupt processing

When an interrupt occurs, a program at an interrupt address is executed after branching a data store sequence to stack register. Write the branch instruction to an interrupt service routine at an interrupt address. Use the RTI instruction to return to main routine. Interrupt enabled by executing the EI instruction is performed after executing 1 instruction (just after the next instruction is executed). Accordingly, when the EI instruction is executed just before the RTI instruction, interrupts are enabled after returning the main routine. (Refer to Figure 13)



Fig. 13 Program example of interrupt processing



Fig. 14 Internal state when interrupt occurs



Fig. 15 Interrupt system diagram



### SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### (6) Control register related to interrupt

Timer control register V1
 Interrupt enable bits of external and timer 1 are assigned to register V1. Set the contents of this register through register A with the TV1A instruction. The TAV1 instruction

can be used to transfer the contents of register V1 to register

A.

### Table 6 Control register related to interrupt

|                 | Timer control register V1                 | at reset : 00002                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | at RAM back-up : 00002  | R/W                          |                                |       |
|-----------------|-------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------------------------|--------------------------------|-------|
| V13             | C./Tour pin function adjection bit        | 0                                               | Port G <sub>1</sub> (I/O)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                         |                              |                                |       |
| V 13            | G1/Tout pin function selection bit        | 1 Τουτ pin (output)/port G <sub>1</sub> (       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (input)                 |                              |                                |       |
| \/10            | V12 Prescaler/timer 1 operation start bit |                                                 | December 4 and the state of the | 0                       | Prescaler stop (initial stat | te) / timer 1 stop (state reta | ined) |
| V 12            |                                           |                                                 | Prescaler / timer 1 operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                         |                              |                                |       |
| V1 <sub>1</sub> | Timer 1 interrupt enable bit              | 0                                               | Interrupt disabled (SNZ1 instruction is valid)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                         |                              |                                |       |
| V 11            | Timer Timerrupt enable bit                | Interrupt enabled (SNZ1 instruction is invalid) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                         |                              |                                |       |
| \/10            | V10 External interrupt enable bit         |                                                 | 0 Interrupt disabled (SNZ0 instruction is valid)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                         |                              |                                |       |
| V 10            |                                           |                                                 | Interrupt enabled (SNZ0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | instruction is invalid) |                              |                                |       |

Note: "R" represents read enabled, and "W" represents write enabled.

### (7) Interrupt sequence

Interrupts occur only when the respective INTE flag, interrupt enable bits (V10, V11), and interrupt request flags (EXF0, T1F) are "1." The interrupt actually occurs 2 to 3 machine cycles after the cycle in which all three conditions are satisfied. The

interrupt occurs after 3 machine cycles only when the three interrupt conditions are satisfied on execution of other than one-cycle instructions (Refer to Figure 16).



Fig. 16 Interrupt sequence



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **EXTERNAL INTERRUPTS**

The 4250 Group has an external interrupt. An external interrupt request occurs when a valid waveform is input to an interrupt input pin (edge detection).

The external interrupt can be controlled with the key-on wakeup control register K0.

Table 7 External interrupt activated condition

| Name               | Input pin           | Valid waveform             | Valid waveform selection bit(K0 <sub>2</sub> ) |
|--------------------|---------------------|----------------------------|------------------------------------------------|
| External interrupt | G <sub>0</sub> /INT | Falling waveform ("H"→"L") | 1                                              |
|                    |                     | Rising waveform ("L"→"H")  | 0                                              |



Fig. 17 External interrupt circuit structure

### SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### (1) External interrupt request flag (EXF0)

External interrupt request flag (EXF0) is set to "1" when a valid waveform is input to Go/INT pin.

The valid waveforms causing the interrupt must be retained at their level for 5 cycles or more of  $f(X_{IN})$  (Refer to Figure 16).

The state of EXF0 flag can be examined with the skip instruction (SNZ0). Use the timer control register V1 to select the interrupt or the skip instruction. The EXF0 flag is cleared to "0" when an interrupt occurs or when the next instruction is skipped with the skip instruction.

- · External interrupt activated condition
  - External interrupt activated condition is satisfied when a valid waveform is input to  $G_0/INT$  pin.
  - The valid waveform can be selected from rising waveform or falling waveform. An example of how to use the external interrupt is as follows.
- ① Select the valid waveform with the bit 2 of register K0.
- ② Clear the EXF0 flag to "0" with the SNZ0 instruction.
- Set the NOP instruction for the case when a skip is performed with the SNZ0 instruction.
- Set both the external interrupt enable bit (V1<sub>0</sub>) and the INTE flag to "1."

The external interrupt is now enabled. Now when a valid waveform is input to the Go/INT pin, the EXF0 flag is set to "1" and the external interrupt occurs.

### (2) Control register related to external interrupt

Key-on wakeup control register K0

Register K0 controls the valid waveform for the external interrupt and key-on wakeup function. Set the contents of this register through register A with the TK0A instruction. The TAK0 instruction can be used to transfer the contents of register K0 to register A.

Table 8 Control register related to external interrupt

| ı               | Key-on wakeup control register K0                                              | at | reset: 00002           | at RAM back-up : state retained | R/W |
|-----------------|--------------------------------------------------------------------------------|----|------------------------|---------------------------------|-----|
| 1/0-            | 60 10 11 11 11 11 11                                                           |    | Instruction clock di   | vided by 4                      | •   |
| K03             | Prescaler dividing ratio selection bit                                         | 1  | Instruction clock di   | vided by 512                    |     |
|                 | Interrupt valid waveform for INT pin/                                          | 0  | Rising waveform ("     | L" → "H")                       |     |
| K0 <sub>2</sub> | key-on wakeup valid waveform selection bit (Note 2)                            | 1  | Falling waveform ('    | "H" → "L")                      |     |
| 1/0             | Parts C. Calkey on walkeyn control hit                                         | 0  | Key-on wakeup no       | t used                          |     |
| K01             | Ports G1–G3 key-on wakeup control bit                                          | 1  | Key-on wakeup use      | ed ("L" level recognized)       |     |
| VO.             | I/O Porto Co Co kou en wokoun control hit                                      | 0  | Key-on wakeup not used |                                 |     |
| NO0             | K0 <sub>0</sub> Ports S <sub>0</sub> –S <sub>3</sub> key-on wakeup control bit |    | Key-on wakeup use      | ed ("L" level recognized)       |     |

Notes 1: "R" represents read enabled, and "W" represents write enabled.

2: Set a value to the bit 2 of register K0, and execute the SNZ0 instruction to clear the EXF0 flag to "0" after executing at least one instruction. According to the input state of Go/INT pin, the external interrupt request flag (EXF0) may be set to "1" when the interrupt valid waveform is changed.



### **TIMERS**

The 4250 Group has the programmable timer.

· Programmable timer

The programmable timer has a reload register and enables the frequency dividing ratio to be set. It is decremented from a setting value n. When it underflows (count to n+1), a timer interrupt request flag is set to "1," new data is loaded from the reload register, and count continues (auto-reload function).



Fig. 18 Auto-reload function

### SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

The 4250 Group timer consists of the following circuits.

- Prescaler : frequency divider
- Timer 1: 8-bit programmable timer with the interrupt function

These timers can be controlled with the timer control register V1 and key-on wakeup control register K0. Each function is described below.

### **Table 9 Function related timers**

| Circuit   | Structure           | Count source             | Frequency dividing ratio | Use of output signal | Control register |
|-----------|---------------------|--------------------------|--------------------------|----------------------|------------------|
| Prescaler | Frequency divider   | Instruction clock        | 4, 512                   | Timer 1 count source | V1               |
|           |                     |                          |                          |                      | K0               |
| Timer 1   | 8-bit programmable  | Prescaler output (ORCLK) | 1 to 256                 | • Tout pin           | V1               |
|           | binary down counter |                          |                          | Timer 1 interrupt    |                  |



Fig. 19 Timers structure

### SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

Table 10 Control registers related to timer

|                 | Timer control register V1                                      | at reset : 00002                                  |                                           | at RAM back-up : 00002                         | R/W |  |
|-----------------|----------------------------------------------------------------|---------------------------------------------------|-------------------------------------------|------------------------------------------------|-----|--|
|                 |                                                                | 0 Port G <sub>1</sub> (I/O)                       |                                           |                                                |     |  |
| V13             | G1/To∪⊤ pin function selection bit                             | 1                                                 | Тоит pin (output)/p                       | ort G <sub>1</sub> (input)                     |     |  |
| \/4-            | Draggler/timer 4 energtion start hit                           | 0                                                 | Prescaler stop (init                      | ial state) / timer 1 stop (state retained)     | )   |  |
| V12             | Prescaler/timer 1 operation start bit                          | 1                                                 | Prescaler / timer 1                       | operation                                      |     |  |
| V1 <sub>1</sub> | Timer 1 interrupt enable bit                                   | 0                                                 | Interrupt disabled (                      | SNZ1 instruction is valid)                     |     |  |
| V 11            | Timer 1 interrupt enable bit                                   | 1                                                 | Interrupt enabled (                       | SNZ1 instruction is invalid)                   |     |  |
| V10             | External interrupt anable hit                                  | 0                                                 | Interrupt disabled (                      | Interrupt disabled (SNZ0 instruction is valid) |     |  |
| V 10            | External interrupt enable bit                                  | 1 Interrupt enabled (SNZ0 instruction is invalid) |                                           | SNZ0 instruction is invalid)                   |     |  |
| ŀ               | Key-on wakeup control register K0                              |                                                   | reset: 00002                              | at RAM back-up : state retained                | R/W |  |
| K0°             | Prescaler dividing ratio selection bit                         | 0                                                 | Instruction clock divided by 4            |                                                |     |  |
| K03             | Frescaler dividing fallo selection bit                         | 1                                                 | Instruction clock divided by 512          |                                                |     |  |
| 1/0             | Interrupt valid waveform for INT pin/                          | 0                                                 | 0 Rising waveform ("L" → "H")             |                                                |     |  |
| K02             | key-on wakeup valid waveform selection bit (Note 2)            | 1                                                 | 1 Falling waveform ("H" → "L")            |                                                |     |  |
| K01             | Ports G <sub>1</sub> –G <sub>3</sub> key-on wakeup control bit | 0                                                 | Key-on wakeup not used                    |                                                |     |  |
| KU1             | Forts G1-G3 key-on wakeup control bit                          | 1                                                 | Key-on wakeup used ("L" level recognized) |                                                |     |  |
| K00             | Ports S <sub>0</sub> –S <sub>3</sub> key-on wakeup control bit | 0                                                 | Key-on wakeup not used                    |                                                |     |  |
| 1.00            | K00 Ports 50–53 key-on wakeup control bit                      |                                                   | Key-on wakeup used ("L" level recognized) |                                                |     |  |

Notes 1: "R" represents read enabled, and "W" represents write enabled.

<sup>2:</sup> Set a value to the bit 2 of register K0, and execute the SNZ0 instruction to clear the EXF0 flag to "0" after executing at least one instruction. According to the input state of Go/INT pin, the external interrupt request flag (EXF0) may be set to "1" when the interrupt valid waveform is changed.

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### (1) Control registers related to timer

### · Timer control register V1

G1/Tout pin function selection bit and prescaler/timer 1 operation start bit are assigned to register V1. Set the contents of this register through register A with the TV1A instruction. The TAV1 instruction can be used to transfer the contents of register V1 to register A.

Key-on wakeup control register K0

Prescaler dividing ratio selection bit is assigned to register K0. Set the contents of this register through register A with the TK0A instruction. The TAK0 instruction can be used to transfer the contents of register K0 to register A.

### (2) Precautions

Note the following for the use of timers.

Prescaler

Stop the prescaler operation to change its frequency dividing ratio

· Reading the count value

Stop timer 1 counting and then execute the TAB1 instruction to read its data.

### (3) Prescaler

Prescaler is a frequency divider. Its frequency dividing ratio can be selected. The count source of prescaler is the instruction clock

Use the bit 3 of register K0 to select the prescaler dividing ratio and the bit 2 of register V1 to start and stop its operation. Prescaler is initialized, and the output signal (ORCLK) stops when the bit 2 of register V1 is cleared to "0."

### (4) Timer 1 (interrupt function)

Timer 1 is an 8-bit binary down counter with the timer 1 reload register (R1). Data can be set simultaneously in timer 1 and the reload register (R1) with the T1AB instruction.

Timer 1 starts counting after the following process;

① set data in timer 1, and

2 set the bit 2 of register V1 to "1."

Once count is started, when timer 1 underflows (the next count pulse is input after the contents of timer 1 becomes "0"), the timer 1 interrupt request flag (T1F) is set to "1," new data is loaded from reload register R1, and count continues (autoreload function).

When a value set in reload register R1 is n, timer 1 divides the count source signal by n + 1 (n = 0 to 255).

Data can be read from timer 1 to registers A and B with the TAB1 instruction. When reading the data, stop the counter and then execute the TAB1 instruction. Timer 1 underflow signal divided by 2 can be output from G1/TouT pin.

### (5) Timer output pin (G1/Τουτ)

Timer output pin (G1/TouT) has the function to output the timer 1 underflow signal divided by 2. The selection of G1/TouT pin function can be controlled with the bit 3 of register V1.

### (6) Timer interrupt request flag (T1F)

Timer interrupt request flag is set to "1" when the timer underflows. The state of this flag can be examined with the skip instruction (SNZ1).

Use the register V1 to select an interrupt or a skip instruction. T1F flag is cleared to "0" when an interrupt occurs or when the next instruction is skipped with a skip instruction.



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **RESET FUNCTION**

System reset is performed by applying "L" level to  $\overline{\text{RESET}}$  pin for 1 machine cycle or more when the following condition is satisfied;

 the value of supply voltage is the minimum value or more of the recommended operating conditions. Then when "H" level is applied to  $\overline{\text{RESET}}$  pin, software starts from address 0 in page 0.



Fig. 20 Reset release timing



Fig. 21 RESET pin input waveform and reset operation

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### (1) Power-on reset

Reset can be automatically performed at power on (power-on reset) by connecting a resistor, a diode, and a capacitor to RESET pin. Connect RESET pin and the external circuit at the shortest distance.



Fig. 22 Power-on reset circuit example

### (2) Internal state at reset

Table 11 shows port state at reset, and Figure 23 shows internal state at reset (they are retained after system is released from reset).

The contents of timers, registers, flags and RAM except shown in Figure 23 are undefined, so set the initial value to them.

Table 11 Port state at reset

| Name                                                                   | Function                                                               | State          |
|------------------------------------------------------------------------|------------------------------------------------------------------------|----------------|
| D <sub>0</sub> , D <sub>1</sub> , D <sub>2</sub> /C, D <sub>3</sub> /K | D <sub>0</sub> , D <sub>1</sub> , D <sub>2</sub> /C, D <sub>3</sub> /K |                |
| S0-S3                                                                  | S0-S3                                                                  | High impedance |
| Go/INT, G1/Tout                                                        | G <sub>0</sub> /INT, G <sub>1</sub>                                    | High impedance |
| G2, G3                                                                 | G2, G3                                                                 | (Note)         |
| Fo, F1                                                                 | Fo, F1                                                                 |                |

Note: Output latch is set to "1."

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

| Program counter (PC)                            |  |
|-------------------------------------------------|--|
| • Interrupt enable flag (INTE)                  |  |
| • Power down flag (P)0                          |  |
| External interrupt request flag (EXF0)          |  |
| Timer 1 interrupt request flag (T1F)            |  |
| Timer control register V1                       |  |
| (Interrupt disabled, prescaler/timer 1 stopped) |  |
| Key-on wakeup control register K0      0 0 0 0  |  |
| Pull-up control register PU0                    |  |
| Logic operation selection register LO           |  |
| • Carry flag (CY)                               |  |
| • Register A                                    |  |
| • Register B                                    |  |
| Stack pointer (SP)                              |  |
|                                                 |  |

Fig. 23 Internal state at reset

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **RAM BACK-UP MODE**

The 4250 Group has the RAM back-up mode.

When the POF instruction is executed continuously, system enters the RAM back-up state.

As oscillation stops retaining RAM, the function of reset circuit and states at RAM back-up mode, current dissipation can be reduced without losing the contents of RAM. Table 12 shows the function and states retained at RAM back-up. Figure 24 shows the state transition.

### (1) Identification of the start condition

Warm start (return from the RAM back-up state) or cold start (return from the normal reset state) can be identified by examining the state of the power down flag (P) with the SNZP instruction.

### (2) Warm start condition

When the external wakeup signal is input after the system enters the RAM back-up state by executing the POF instruction continuously, the CPU starts executing the software from address 0 in page 0. In this case, the P flag is "1."

### (3) Cold start condition

The CPU starts executing the software from address 0 in page 0 when reset pulse is input to RESET pin.

In this case, the P flag is "0."

### (4) Return signal

An external wakeup signal is used to return from the RAM back-up mode. Table 13 shows the return condition for each return source.

Table 12 Functions and states retained at RAM back-up

| Function                                     | RAM back-up |
|----------------------------------------------|-------------|
| Program counter (PC), registers A, B,        | ×           |
| carry flag (CY), stack pointer (SP) (Note 2) | ^           |
| Contents of RAM                              | 0           |
| Port                                         | ×           |
| Timer control register V1                    | ×           |
| Timer 1 function                             | ×           |
| Pull-up control register PU0                 | 0           |
| Key-on wakeup control register K0            | 0           |
| Logic operation selection register LO        | ×           |
| External interrupt request flag (EXF0)       | ×           |
| Timer 1 interrupt request flag (T1F)         | ×           |
| Interrupt enable flag (INTE)                 | ×           |
|                                              |             |

Notes 1: "O" represents that the function can be retained, and "X" represents that the function is initialized.

Registers and flags other than the above are undefined at RAM back-up, and set an initial value after returning.

2:The stack pointer (SP) points the level of the stack register and is initialized to "3" at RAM back-up.

Table 13 Return source and return condition

| . Return source | Return condition                  | Remarks                                                                         |
|-----------------|-----------------------------------|---------------------------------------------------------------------------------|
| Go/INT pin      | Return by an external rising edge | Select the return edge (rising edge or falling edge) with the bit 2 of register |
|                 | input ("L"→"H") or falling edge   | K0 according to the external state before going into the RAM back-up            |
|                 | input ("H"→"L").                  | state.                                                                          |
|                 | The EXF0 flag is not set.         |                                                                                 |
| Ports G1-G3     | Return by an external "L" level   | Set the port using the key-on wakeup function selected with register K0         |
| S0-S3           | input.                            | to "H" level before going into the RAM back-up state.                           |

Note:  $G_0/INT$  pin and ports  $G_1-G_3$ ,  $S_0-S_3$  share the circuit which is used to detect the edge and to recognize "L" level. The  $G_0/INT$  pin cannot be set to "no key-on wakeup."



### SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### (5) Key-on wakeup control register K0

Key-on wakeup control register K0

The interrupt valid waveform for INT pin/key-on wakeup valid waveform selection bit, the ports G<sub>1</sub>–G<sub>3</sub> key-on wakeup control bit and the ports S<sub>0</sub>–S<sub>3</sub> key-on wakeup control bit are assigned to the register K0. Set the contents

of this register through register A with the TK0A instruction. The TAK0 instruction can be used to transfer the contents of register K0 to register A.

Table 14 Key-on wakeup control register

|      | Key-on wakeup control register K0                                               | at | reset : 00002         | at RAM back-up : state retained | R/W |
|------|---------------------------------------------------------------------------------|----|-----------------------|---------------------------------|-----|
| 1/0- | Draggeler dividing ratio coloction hit                                          | 0  | Instruction clock div | vided by 4                      |     |
| K0₃  | Prescaler dividing ratio selection bit                                          | 1  | Instruction clock div | vided by 512                    |     |
| K02  | Interrupt valid waveform for INT pin/<br>key-on wakeup valid waveform selection | 0  | Rising waveform ("    | L" → "H")                       |     |
| KU2  | bit (Note 2)                                                                    | 1  | Falling waveform (    | 'H" → "L")                      |     |
| 1/0. | Porto C. Co kov on wakoup central hit                                           | 0  | Key-on wakeup no      | t used                          |     |
| K0₁  | Ports G <sub>1</sub> –G <sub>3</sub> key-on wakeup control bit                  |    | Key-on wakeup use     | ed ("L" level recognized)       |     |
| K0°  | K0 <sub>0</sub> Ports S <sub>0</sub> –S <sub>3</sub> key-on wakeup control bit  |    | Key-on wakeup no      | t used                          |     |
| K00  |                                                                                 |    | Key-on wakeup use     | ed ("L" level recognized)       |     |

Notes 1: "R" represents read enabled, and "W" represents write enabled.

2: Set a value to the bit 2 of register K0, and execute the SNZ0 instruction to clear the EXF0 flag after executing at least one instruction. According to the input state of Go/INT pin, the external interrupt request flag (EXF0) may be set when the interrupt valid waveform is changed.



Fig. 24 State transition



Fig. 25 Set source and clear source of the P flag



Fig. 26 Start condition identified example using the SNZP instruction



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **CLOCK CONTROL**

The clock control circuit consists of the following circuits.

- · System clock generating circuit
- · Control circuit to stop the clock oscillation
- · Control circuit to return from the RAM back-up state



Fig. 27 Clock control circuit structure

Clock signal  $f(X_{IN})$  is obtained by connecting  $X_{IN}$  pin and  $X_{OUT}$  pin directly, and externally connecting a resistor to  $X_{IN}$  and a capacitor to  $X_{OUT}$ . Connect this external circuit to pins  $X_{IN}$  and  $X_{OUT}$  at the shortest distance.

When an external clock signal is input, note the input waveform (refer to the list of precaution).

### **ROM ORDERING METHOD**

Please submit the information described below when ordering Mask ROM.

- (1) M34250M2-XXXFP Mask ROM Order Confirmation Form
- (2) Data to be written into mask ROM ...... EPROM (three sets containing the identical data)
- (3) Mark Specification Form ...... 1



Fig. 28 Resistor and capacitor external circuit

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### LIST OF PRECAUTIONS

### Noise and latch-up prevention

Connect a capacitor on the following condition to prevent noise and latch-up;

- connect a bypass capacitor (approx. 0.01 μF) between pins Vpb and Vss at the shortest distance,
- · equalize its wiring in width and length, and
- use the thickest wire.
   In the One Time PROM version, CNVss pin is also used as VPP pin. Connect this pin to Vss through the resistor about 5 kΩ which is assigned to CNVss/VPP pin as close as possible at the shortest distance.

### ② Prescaler

Stop the prescaler operation to change its frequency dividing ratio.

### ③ Timer count source

Stop timer 1 counting to change its count source.

### Program counter

Make sure that the PCH does not specify after the last page of the built-in ROM.

### ⑤ G₀/INT pin

When the interrupt valid waveform of the G<sub>0</sub>/INT pin is changed with the bit 2 of register K0 in software, be careful about the following notes.

- After clear the bit 0 of register V1 to "0" (Figure 29<sup>①</sup>), change the interrupt valid waveform of Go/INT pin with the bit 2 of register K0.
- Set a value to bit 2 of register K0 and execute the SNZ0 instruction to clear the external interrupt request flag (EXF0) after executing at least one instruction (refer to Figure 29<sup>2</sup>). Depending on the input state of the Go/INT pin, the EXF0 flag may be set when the interrupt valid waveform is changed.



Fig. 29 External interrupt program example

### Notes on unused pins

- When pins Go/INT, G1/Τουτ, G2 and G3 are connected to Vss pin, turn off their pull-up transistors (register PU0="X02") and also invalidate the key-on wakeup functions of pins G1/Τουτ, G2 and G3 (register K0="XX0X2") by software. When the POF instruction is executed while these pins are connected to Vss and the key-on wakeup functions are left valid, the system returns from RAM back-up state by recognizing the return condition immediately after going into the RAM back-up state. When these pins are open, turn on their pull-up transistors (register PU0="X12") by software.
- When ports S<sub>0</sub>-S<sub>3</sub> are connected to Vss pin, invalidate the key-on wakeup functions (register K0="XXX02") by software. When the POF instruction is executed while these pins are connected to Vss and the key-on wakeup functions are left valid, the system returns from RAM back-up state by recognizing the return condition immediately after going into the RAM back-up state.
- When ports D<sub>2</sub>/C and D<sub>3</sub>/K are connected to Vss pin, turn off their pull-up transistors (register PU0="0X2") by software.
   When these pins are open, turn on their pull-up transistors (register PU0="1X2") by software.

(Note when connecting to Vss and VDD)

 Connect the unused pins to Vss or Vpp at the shortest distance (within 20 mm) and use the thick wire against noise.

### Multifunction

- Go/INT pin can be also used as an I/O port Go even when it is used as INT pin.
- G1/Touτ pin can be also used as input port G1 even when it is used as Touτ pin.
- D2/C pin can be also used as I/O port D2 even when it is used as port C.
- D<sub>3</sub>/K pin can be also used as I/O port D<sub>3</sub> even when it is used as port K.



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### ® Key-on wakeup

When system returns from RAM back-up state by using the Go/INT pin, select the return edge (rising edge or falling edge) with the bit 2 of register K0 according to the external state before going into the RAM back-up state.

When system returns from RAM back-up state by using the ports  $G_1$ – $G_3$  and  $S_0$ – $S_3$ , set the port using the key-on wakeup function selected with register K0 to "H" level before going into the RAM back-up state.

 $G_0$ /INT pin and ports  $G_1$ – $G_3$ ,  $S_0$ – $S_3$  share the circuit which is used to detect the edge and to recognize "L" level.

The Go/INT pin cannot be set to "no key-on wakeup."

### External clock input waveform

When the external clock is used, open XouT pin, and input the clock waveform into XIN pin shown below. (Refer to Figure 30)
•Duty ratio = 50 %.

•"H" level input voltage=VDD (V), "L" level input voltage=Vss (V).



Fig. 30 External clock input waveform

### CR oscillation constant

Use the external 30 pF capacitor and enable to change the frequency by the external resistor.

Test the system sufficiently because the oscillation constant depends on the ROM type (mask ROM or PROM).

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

SYMBOL

The symbols shown below are used in the following list of instruction function and the machine instructions.

| Symbol | Contents                                       | Symbol            | Contents                                                            |
|--------|------------------------------------------------|-------------------|---------------------------------------------------------------------|
| A      | Register A (4 bits)                            | D                 | Port D (4 bits)                                                     |
| В      | Register B (4 bits)                            | F                 | Port F (2 bits)                                                     |
| DR     | Register D (3 bits)                            | G                 | Port G (4 bits)                                                     |
| E      | Register E (8 bits)                            | S                 | Port S (4 bits)                                                     |
| V1     | Timer control register V1 (4 bits)             | K                 | Port K (1 bit)                                                      |
| K0     | Key-on wakeup control register K0 (4 bits)     | С                 | Port C (1 bit)                                                      |
| PU0    | Pull-up control register PU0 (2 bits)          |                   |                                                                     |
| LO     | Logic operation selection register LO (2 bits) | x                 | Hexadecimal variable                                                |
|        |                                                | у                 | Hexadecimal variable                                                |
| X      | Register X (2 bits)                            | р                 | Hexadecimal variable                                                |
| Υ      | Register Y (4 bits)                            | n                 | Hexadecimal constant which represents the                           |
| DP     | Data pointer (6 bits)                          |                   | immediate value                                                     |
|        | (It consists of registers X and Y)             | j                 | Hexadecimal constant which represents the                           |
| PC     | Program counter (11 bits)                      |                   | immediate value                                                     |
| РСн    | High-order 4 bits of program counter           | A3A2A1A0          | Binary notation of hexadecimal variable A                           |
| PCL    | Low-order 7 bits of program counter            |                   | (same for others)                                                   |
| SK     | Stack register (11 bits X 4)                   |                   |                                                                     |
| SP     | Stack pointer (2 bits)                         | $\leftarrow$      | Direction of data movement                                          |
| CY     | Carry flag                                     | $\leftrightarrow$ | Data exchange between a register and memory                         |
| R1     | Timer 1 reload register                        | ?                 | Decision of state shown before "?"                                  |
| T1     | Timer 1                                        | ( )               | Contents of registers and memories                                  |
| T1F    | Timer 1 interrupt request flag                 | _                 | Negate, Flag unchanged after executing                              |
| INTE   | Interrupt enable flag                          |                   | instruction                                                         |
| EXF0   | External interrupt request flag                | M(DP)             | RAM address pointed by the data pointer                             |
| Р      | Power down flag                                | а                 | Label indicating address a6 a5 a4 a3 a2 a1 a0                       |
|        |                                                | p, a              | Label indicating address as a      |
|        |                                                |                   | in page p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub> |
|        |                                                | С                 | Hex. C + Hex. number x (also same for others)                       |
|        |                                                | +                 |                                                                     |
|        |                                                | x                 |                                                                     |

Note: The 4250 Group just invalidates the next instruction when a skip is performed. The contents of program counter is not increased by 2. Accordingly, the number of cycles does not change even if skip is not performed. However, the cycle count becomes "1" if the TABP p, RT, or RTS instruction is skipped.

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### LIST OF INSTRUCTION FUNCTION

| Grouping                      | Mnemonic | Function                                 | Grouping             | Mnemonic | Function                                  | Grouping              | Mnemonic   | Function                                                                      |
|-------------------------------|----------|------------------------------------------|----------------------|----------|-------------------------------------------|-----------------------|------------|-------------------------------------------------------------------------------|
|                               | TAB      | (A) ← (B)                                |                      | LA n     | (A) ← n                                   | Ē                     | SEAM       | (A) = (M(DP)) ?                                                               |
|                               |          |                                          |                      |          | n = 0 to 15                               | ompariso<br>operation |            |                                                                               |
|                               | TBA      | (B) ← (A)                                |                      |          |                                           | npa<br>erat           | SEA n      | (A) = n ?                                                                     |
|                               |          |                                          |                      | TABP p   | (SP) ← (SP) + 1                           | Comparison operation  |            | n = 0 to 15                                                                   |
| sfe                           | TAY      | $(A) \leftarrow (Y)$                     |                      |          | $(SK(SP)) \leftarrow (PC)$                |                       |            |                                                                               |
| Register to register transfer |          |                                          |                      |          | (PCн) ← p                                 |                       | Ва         | (PCL) ← a6–a0                                                                 |
| ter                           | TYA      | $(Y) \leftarrow (A)$                     |                      |          | $(PCL) \leftarrow (DR_2-DR_0,$            |                       |            |                                                                               |
| gis                           |          |                                          |                      |          | A3-A0)                                    | u                     | BL p, a    | (РСн) ← р                                                                     |
| 0 6                           | TEAB     | (E7−E4) ← (B)                            |                      |          | (B) $\leftarrow$ (ROM(PC))7 to 4          | Branch operation      |            | (PCL) ← a6-a0                                                                 |
| ert                           |          | $(E_3-E_0) \leftarrow (A)$               |                      |          | $(A) \leftarrow (ROM(PC))3 \text{ to } 0$ | obe                   |            |                                                                               |
| gist                          |          |                                          |                      |          | $(PC) \leftarrow (SK(SP))$                | -C                    | BA a       | $(PCL) \leftarrow (a_6-a_4, A_3-A_0)$                                         |
| &<br>&                        | TABE     | (B) ← (E7–E4)                            |                      |          | (SP) ← (SP) – 1                           | ran                   |            | ,                                                                             |
|                               |          | (A) ← (E3–E0)                            |                      |          | (1) (1) (1/25)                            | ш                     | BLA p, a   | (PCH) ← p                                                                     |
|                               |          | (55 55) (4 4)                            |                      | AM       | $(A) \leftarrow (A) + (M(DP))$            |                       |            | $(PCL) \leftarrow (a_6-a_4, A_3-A_0)$                                         |
|                               | TDA      | $(DR_2-DR_0) \leftarrow (A_2-A_0)$       | _                    | 4440     | (4) (4) (44(DD))                          |                       | DM -       | (OD) (OD) 4                                                                   |
|                               | 1 ///    | ()()                                     | Arithmetic operation | AMC      | $(A) \leftarrow (A) + (M(DP))$            |                       | ВМа        | $(SP) \leftarrow (SP) + 1$                                                    |
| ω                             | LXY x, y | $(X) \leftarrow x, x = 0 \text{ to } 3$  | ber                  |          | + (CY)                                    |                       |            | $(SK(SP)) \leftarrow (PC)$                                                    |
| sse                           |          | $(Y) \leftarrow y, y = 0 \text{ to } 15$ | 0 0                  |          | (CY) ← Carry                              |                       |            | (PC <sub>H</sub> ) ← 2<br>(PC <sub>L</sub> ) ← a <sub>6</sub> –a <sub>0</sub> |
| RAM addresses                 | INY      | (Y) ← (Y) + 1                            | neti                 | A n      | (A) ← (A) + n                             |                       |            | (PCL) ← a6-a0                                                                 |
| ad<br>g                       |          | (1) ← (1) + 1                            | į                    | AII      | n = 0  to  15                             | tion                  | DMI n o    | (SP) ← (SP) + 1                                                               |
| AM                            | DEY      | (Y) ← (Y) − 1                            | Ā                    |          | 11 = 0 to 13                              | era                   | DIVIL p, a | $(SK(SP)) \leftarrow (PC)$                                                    |
| ~                             |          | (1) ← (1) − 1                            |                      | sc       | (CY) ← 1                                  | Subroutine operation  |            | (SK(SF)) ← (FC)<br>(PCH) ← p                                                  |
|                               | TAM j    | $(A) \leftarrow (M(DP))$                 |                      | 30       | (01) ← 1                                  | tine                  |            | (PCL) ← a6–a0                                                                 |
|                               | 17 (17)  | $(X) \leftarrow (X) \in (X) \in (X)$     |                      | RC       | (CY) ← 0                                  | l                     | BMLA p.    | (1 02) \ 40 40                                                                |
|                               |          | j = 0  to  3                             |                      |          |                                           | Suk                   |            | (SP) ← (SP) + 1                                                               |
|                               |          | ,                                        |                      | SZC      | (CY) = 0 ?                                |                       | a          | $(SK(SP)) \leftarrow (PC)$                                                    |
|                               | XAM j    | $(A) \longleftrightarrow (M(DP))$        |                      |          | ,                                         |                       |            | (PCH) ← p                                                                     |
|                               | ,        | $(X) \leftarrow (X) EXOR(j)$             |                      | СМА      | $(A) \leftarrow (\overline{A})$           |                       |            | $(PCL) \leftarrow (a_6-a_4, A_3-A_0)$                                         |
|                               |          | j = 0 to 3                               |                      |          |                                           |                       |            | ,                                                                             |
| fer                           |          |                                          |                      | RAR      | $\rightarrow$ CY $\rightarrow$ A3A2A1A0   |                       | RTI        | $(PC) \leftarrow (SK(SP))$                                                    |
| ter transfer                  | XAMD j   | $(A) \longleftrightarrow (M(DP))$        |                      |          |                                           |                       |            | (SP) ← (SP) – 1                                                               |
| ır tr                         |          | $(X) \leftarrow (X) EXOR(j)$             |                      | LGOP     | Logic operation                           |                       |            |                                                                               |
|                               |          | j = 0 to 3                               |                      |          | instruction                               |                       | RT         | $(PC) \leftarrow (SK(SP))$                                                    |
| reç                           |          | $(Y) \leftarrow (Y) - 1$                 |                      |          | XOR, OR, AND                              | ے                     |            | (SP) ← (SP) − 1                                                               |
| 1 to                          |          |                                          |                      |          |                                           | atio                  |            |                                                                               |
| RAM to regis                  | XAMI j   | $(A) \longleftrightarrow (M(DP))$        |                      | SB j     | (Mj(DP)) ← 1                              | per                   | RTS        | $(PC) \leftarrow (SK(SP))$                                                    |
|                               |          | $(X) \leftarrow (X) EXOR(j)$             |                      |          | j = 0 to 3                                | 0                     |            | (SP) ← (SP) − 1                                                               |
|                               |          | j = 0 to 3                               | ion                  |          |                                           | Return operation      |            |                                                                               |
|                               |          | (Y) ← (Y) + 1                            | erat                 | RB j     | $(Mj(DP)) \leftarrow 0$                   | <u>~</u>              |            |                                                                               |
|                               |          |                                          | Bit operation        |          | j = 0 to 3                                |                       |            |                                                                               |
|                               |          |                                          | Bit                  |          |                                           |                       |            |                                                                               |
|                               |          |                                          |                      | SZB j    | (Mj(DP)) = 0 ?                            |                       |            |                                                                               |
|                               |          |                                          |                      |          | j = 0 to 3                                |                       |            |                                                                               |

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

# LIST OF INSTRUCTION FUNCTION (CONTINUED)

| Grouping            | Mnemonic | Function                                                                         | Grouping               | Mnemonic   | Function                                                   | Grouping        | Mnemonic     | Function                                 |
|---------------------|----------|----------------------------------------------------------------------------------|------------------------|------------|------------------------------------------------------------|-----------------|--------------|------------------------------------------|
|                     | DI       | INTE← 0                                                                          |                        | CLD        | (D) ← 1                                                    |                 | NOP          | (PC) ← (PC) + 1                          |
| oeration            | EI       | INTE ← 1                                                                         |                        | RD         | $ (D(Y)) \leftarrow 0 $ $ (Y) = 0 \text{ to } 3 $          |                 | POF          | RAM back-up                              |
| Interrupt operation | SNZ0     | (EXF0) = 1 ? After skipping the next instruction                                 |                        | SD         | $(D(Y)) \leftarrow 1$ $(Y) = 0 \text{ to } 3$              | c               | SNZP<br>TLOA | $(P) = 1 ?$ $(LO) \leftarrow (A_1, A_0)$ |
| <u>n</u>            |          | (EXF0) ← 0                                                                       |                        | SZD        | (D(Y)) = 0?                                                | Other operation | TV1A         | $(V1) \leftarrow (A)$                    |
| tion                | TAB1     | $(B) \leftarrow (T17-T14)$ $(A) \leftarrow (T13-T10)$                            |                        |            | (Y) = 0  to  3                                             | Other           | TAV1         | (A) ← (V1)                               |
| Timer operation     | T1AB     | $(R17-R14) \leftarrow (B)$<br>$(T17-T14) \leftarrow (B)$                         | ration                 | SCP<br>RCP | $(C) \leftarrow 1$ $(C) \leftarrow 0$                      |                 | TK0A         | (K0) ← (A)                               |
| Time                |          | $(R13-R10) \leftarrow (A)$ $(R13-R10) \leftarrow (A)$ $(T13-T10) \leftarrow (A)$ | Input/Output operation | SNZCP      | (C) ← 0<br>(C) = 1?                                        |                 | TAK0         | (A) ← (K0)                               |
|                     | SNZ1     | (T1F) = 1 ?                                                                      | ıput/Out               | OFA        | $(F) \leftarrow (A_1, A_0)$                                |                 | TPU0A        | (PU0) ← (A)                              |
|                     |          | After skipping the next instruction $ (T1F) \leftarrow 0 $                       | ıl                     | IAF        | $(A_1, A_0) \leftarrow (F)$<br>$(A_3, A_2) \leftarrow (0)$ |                 |              |                                          |
|                     |          |                                                                                  |                        | OGA        | (G) ← (A)                                                  |                 |              |                                          |
|                     |          |                                                                                  |                        | IAG        | $(A) \leftarrow (G)$                                       |                 |              |                                          |
|                     |          |                                                                                  |                        | OSA        | $(S) \leftarrow (A)$                                       |                 |              |                                          |
|                     |          |                                                                                  |                        | IAS        | $(A) \leftarrow (S)$                                       |                 |              |                                          |
|                     |          |                                                                                  |                        | OKA<br>IAK | $(K) \leftarrow (A_0)$<br>$(A_0) \leftarrow (K),$          |                 |              |                                          |
|                     |          |                                                                                  |                        | ,,,,       | $(A_3, A_2, A_1) \leftarrow (0)$                           |                 |              |                                          |
|                     |          |                                                                                  |                        |            |                                                            |                 |              |                                          |
|                     |          |                                                                                  |                        |            |                                                            |                 |              |                                          |
|                     |          |                                                                                  |                        |            |                                                            |                 |              |                                          |
|                     |          |                                                                                  |                        |            |                                                            |                 |              |                                          |
|                     |          |                                                                                  |                        |            |                                                            |                 |              |                                          |

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **INSTRUCTION CODE TABLE**

|           | D8-D4            | 00000 | 00001 | 00010    | 00011 | 00100   | 00101   | 00110     | 00111 | 01000 | 01001      | 01010   | 01011    | 01100       | 01101       | 01110       | 01111       | 10000<br>1<br>10111 | 11000<br>1<br>11111 |
|-----------|------------------|-------|-------|----------|-------|---------|---------|-----------|-------|-------|------------|---------|----------|-------------|-------------|-------------|-------------|---------------------|---------------------|
| D3-<br>D0 | Hex.<br>notation | 00    | 01    | 02       | 03    | 04      | 05      | 06        | 07    | 08    | 09         | 0A      | 0B       | 0C          | 0D          | 0E          | 0F          | 10 to 17            | 18 to 1F            |
| 0000      | 0                | NOP   | BLA   | SZB<br>0 | BL    | _       | BMLA    | XAM<br>0  | BML   | OGA   | TABP<br>0  | A<br>0  | LA<br>0  | LXY<br>0,0  | LXY<br>1,0  | LXY<br>2,0  | LXY<br>3,0  | ВМ                  | В                   |
| 0001      | 1                | ВА    | CLD   | SZB<br>1 | BL    | LGOP    | _       | XAM<br>1  | BML   | OKA   | TABP<br>1  | A<br>1  | LA<br>1  | LXY<br>0,1  | LXY<br>1,1  | LXY<br>2,1  | LXY<br>3,1  | ВМ                  | В                   |
| 0010      | 2                | 1     | l     | SZB<br>2 | BL    | 1       | ı       | XAM<br>2  | BML   | SCP   | TABP<br>2  | A<br>2  | LA<br>2  | LXY<br>0,2  | LXY<br>1,2  | LXY<br>2,2  | LXY<br>3,2  | ВМ                  | В                   |
| 0011      | 3                | SNZP  | INY   | SZB<br>3 | BL    |         |         | XAM<br>3  | BML   | RCP   | TABP       | A<br>3  | LA<br>3  | LXY<br>0,3  | LXY<br>1,3  | LXY<br>2,3  | LXY<br>3,3  | ВМ                  | В                   |
| 0100      | 4                | DI    | RD    | SZD      | BL    | RT      | l       | TAM<br>0  | BML   | OFA   | TABP<br>4  | A<br>4  | LA<br>4  | LXY<br>0,4  | LXY<br>1,4  | LXY<br>2,4  | LXY<br>3,4  | ВМ                  | В                   |
| 0101      | 5                | EI    | SD    | SEAn     | BL    | RTS     | IAS     | TAM<br>1  | BML   | T1AB  | TABP<br>5  | A<br>5  | LA<br>5  | LXY<br>0,5  | LXY<br>1,5  | LXY<br>2,5  | LXY<br>3,5  | ВМ                  | В                   |
| 0110      | 6                | RC    | l     | SEAM     | BL    | RTI     | IAF     | TAM<br>2  | BML   | TV1A  | TABP<br>6  | A<br>6  | LA<br>6  | LXY<br>0,6  | LXY<br>1,6  | LXY<br>2,6  | LXY<br>3,6  | ВМ                  | В                   |
| 0111      | 7                | sc    | DEY   | _        | BL    | ĺ       | IAK     | TAM<br>3  | BML   | TK0A  | TABP<br>7  | A<br>7  | LA<br>7  | LXY<br>0,7  | LXY<br>1,7  | LXY<br>2,7  | LXY<br>3,7  | ВМ                  | В                   |
| 1000      | 8                | _     | l     | IAG      | BL    |         | TLOA    | XAMI<br>0 | BML   | TAV1  | TABP<br>8  | A<br>8  | LA<br>8  | LXY<br>0,8  | LXY<br>1,8  | LXY<br>2,8  | LXY<br>3,8  | ВМ                  | В                   |
| 1001      | 9                |       |       | TDA      | BL    | 1       | 1       | XAMI<br>1 | BML   | TAK0  | TABP<br>9  | A<br>9  | LA<br>9  | LXY<br>0,9  | LXY<br>1,9  | LXY<br>2,9  | LXY<br>3,9  | ВМ                  | В                   |
| 1010      | А                | AM    | TEAB  | TABE     | BL    | ı       | I       | XAMI<br>2 | BML   | TAB1  | TABP<br>10 | A<br>10 | LA<br>10 | LXY<br>0,10 | LXY<br>1,10 | LXY<br>2,10 | LXY<br>3,10 | ВМ                  | В                   |
| 1011      | В                | AMC   | OSA   | _        | BL    |         | 1       | XAMI<br>3 | BML   | TPU0A | TABP<br>11 | A<br>11 | LA<br>11 | LXY<br>0,11 | LXY<br>1,11 | LXY<br>2,11 | LXY<br>3,11 | ВМ                  | В                   |
| 1100      | С                | TYA   | СМА   | _        | BL    | RB<br>0 | SB<br>0 | XAMD<br>0 | BML   | SNZ1  | TABP<br>12 | A<br>12 | LA<br>12 | LXY<br>0,12 | LXY<br>1,12 | LXY<br>2,12 | LXY<br>3,12 | ВМ                  | В                   |
| 1101      | D                | POF   | RAR   | _        | BL    | RB<br>1 | SB<br>1 | XAMD<br>1 | BML   | SNZCF | TABP<br>13 | A<br>13 | LA<br>13 | LXY<br>0,13 | LXY<br>1,13 | LXY<br>2,13 | LXY<br>3,13 | ВМ                  | В                   |
| 1110      | Е                | ТВА   | TAB   | _        | BL    | RB<br>2 | SB<br>2 | XAMD<br>2 | BML   | _     | TABP<br>14 | A<br>14 | LA<br>14 | LXY<br>0,14 | LXY<br>1,14 | LXY<br>2,14 | LXY<br>3,14 | ВМ                  | В                   |
| 1111      | F                | _     | TAY   | SZC      | BL    | RB<br>3 | SB<br>3 | XAMD<br>3 | BML   | SNZ0  | TABP<br>15 | A<br>15 | LA<br>15 | LXY<br>0,15 | LXY<br>1,15 | LXY<br>2,15 | LXY<br>3,15 | ВМ                  | В                   |

The above table shows the relationship between machine language codes and machine language instructions. D3–D0 show the low-order 4 bits of the machine language code, and D8–D4 show the high-order 5 bits of the machine language code. The hexadecimal representation of the code is also provided. There are one-word instructions and two-word instructions, but only the first word of each instruction is shown.

The codes for the second word of a two-word instruction are described below.

|      | The second word |         |      |  |  |  |  |  |  |  |
|------|-----------------|---------|------|--|--|--|--|--|--|--|
| BL   | 1               | 1 a a a | aaaa |  |  |  |  |  |  |  |
| BML  | 1               | 0 a a a | aaaa |  |  |  |  |  |  |  |
| ВА   | 1               | 1 a a a | aaaa |  |  |  |  |  |  |  |
| BLA  | 1               | 1 a a a | рррр |  |  |  |  |  |  |  |
| BMLA | 1               | 0 a a a | рррр |  |  |  |  |  |  |  |
| SEA  | 0               | 1011    | nnnn |  |  |  |  |  |  |  |
| SZD  | 0               | 0010    | 1011 |  |  |  |  |  |  |  |

Do not use the code marked "-."



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **MACHINE INSTRUCTIONS**

| Parameter                     |          |    | Instruction code |                |    |            |    |            |            |                |   |              |             | er of<br>ds        | er of<br>es      |                                                                                     |  |  |
|-------------------------------|----------|----|------------------|----------------|----|------------|----|------------|------------|----------------|---|--------------|-------------|--------------------|------------------|-------------------------------------------------------------------------------------|--|--|
| Type of instructions          | Mnemonic | D8 | D7               | D <sub>6</sub> | D5 | D4         | Dз | D2         | D1         | D <sub>0</sub> | l | ade<br>otati | cimal<br>on | Number of<br>words | Number of cycles | Function                                                                            |  |  |
|                               | TAB      | 0  | 0                | 0              | 0  | 1          | 1  | 1          | 1          | 0              | 0 | 1            | Ε           | 1                  | 1                | $(A) \leftarrow (B)$                                                                |  |  |
| fer                           | ТВА      | 0  | 0                | 0              | 0  | 0          | 1  | 1          | 1          | 0              | 0 | 0            | E           | 1                  | 1                | (B) ← (A)                                                                           |  |  |
| r trans                       | TAY      | 0  | 0                | 0              | 0  | 1          | 1  | 1          | 1          | 1              | 0 | 1            | F           | 1                  | 1                | $(A) \leftarrow (Y)$                                                                |  |  |
| Register to register transfer | TYA      | 0  | 0                | 0              | 0  | 0          | 1  | 1          | 0          | 0              | 0 | 0            | С           | 1                  | 1                | $(Y) \leftarrow (A)$                                                                |  |  |
| ster to                       | TEAB     | 0  | 0                | 0              | 0  | 1          | 1  | 0          | 1          | 0              | 0 | 1            | Α           | 1                  | 1                | $(E_7-E_4) \leftarrow (B) (E_3-E_0) \leftarrow (A)$                                 |  |  |
| Regis                         | TABE     | 0  | 0                | 0              | 1  | 0          | 1  | 0          | 1          | 0              | 0 | 2            | Α           | 1                  | 1                | $(B) \leftarrow (E_7 - E_4) (A) \leftarrow (E_3 - E_0)$                             |  |  |
|                               | TDA      | 0  | 0                | 0              | 1  | 0          | 1  | 0          | 0          | 1              | 0 | 2            | 9           | 1                  | 1                | $(DR_2-DR_0) \leftarrow (A_2-A_0)$                                                  |  |  |
|                               | LXY x, y | 0  | 1                | 1              | X1 | <b>X</b> 0 | уз | <b>y</b> 2 | <b>y</b> 1 | y <sub>0</sub> | 0 | C<br>+x      |             | 1                  | 1                | $(X) \leftarrow x, x = 0 \text{ to } 3$<br>$(Y) \leftarrow y, y = 0 \text{ to } 15$ |  |  |
| RAM addresses                 | INY      | 0  | 0                | 0              | 0  | 1          | 0  | 0          | 1          | 1              | 0 | 1            | 3           | 1                  | 1                | (Y) ← (Y) + 1                                                                       |  |  |
| 1                             | DEY      | 0  | 0                | 0              | 0  | 1          | 0  | 1          | 1          | 1              | 0 | 1            | 7           | 1                  | 1                | (Y) ← (Y) − 1                                                                       |  |  |

| Skip condition            | Carry flag CY | Detailed description                                                                                                                                                                                                                                                                |
|---------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _                         | -             | Transfers the contents of register B to register A.                                                                                                                                                                                                                                 |
| _                         | -             | Transfers the contents of register A to register B.                                                                                                                                                                                                                                 |
| -                         | _             | Transfers the contents of register Y to register A.                                                                                                                                                                                                                                 |
| _                         | -             | Transfers the contents of register A to register Y.                                                                                                                                                                                                                                 |
| _                         | -             | Transfers the contents of registers A and B to register E.                                                                                                                                                                                                                          |
| -                         | _             | Transfers the contents of register E to registers A and B.                                                                                                                                                                                                                          |
| -                         | -             | Transfers the contents of register A to register D.                                                                                                                                                                                                                                 |
| Continuous<br>description | _             | Loads the value x in the immediate field to register X, and the value y in the immediate field to register Y.  When the LXY instructions are continuously coded and executed, only the first LXY instruction is executed and other LXY instructions coded continuously are skipped. |
| (Y) = 0                   | _             | Adds 1 to the contents of register Y. As a result of addition, when the contents of register Y is 0, the next instruction is skipped.                                                                                                                                               |
| (Y) = 15                  | _             | Subtracts 1 from the contents of register Y. As a result of subtraction, when the contents of register Y is 15, the next instruction is skipped.                                                                                                                                    |

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

## MACHINE INSTRUCTIONS (CONTINUED)

| Parameter                |          | Instruction code |    |                |    |    |    |                |    | de             |   |               |            | rds<br>rds<br>oer of<br>les |                  |                                                                                                                                 |
|--------------------------|----------|------------------|----|----------------|----|----|----|----------------|----|----------------|---|---------------|------------|-----------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Type of instructions     | Mnemonic | D8               | D7 | D <sub>6</sub> | D5 | D4 | Dз | D <sub>2</sub> | D1 | D <sub>0</sub> | 1 | adeo<br>tatio | imal<br>on | Number of<br>words          | Number of cycles | Function                                                                                                                        |
|                          | ТАМ ј    | 0                | 0  | 1              | 1  | 0  | 0  | 1              | j1 | jo             | 0 | 6             | 4<br>+j    | 1                           | 1                | $(A) \leftarrow (M(DP))$<br>$(X) \leftarrow (X) EXOR(j)$<br>j = 0  to  3                                                        |
| RAM to register transfer | XAM j    | 0                | 0  | 1              | 1  | 0  | 0  | 0              | j1 | jo             | 0 | 6             | j          | 1                           | 1                | $(A) \longleftrightarrow (M(DP))$ $(X) \longleftrightarrow (X) EXOR(j)$ $j = 0 \text{ to } 3$                                   |
| RAM to regi              | XAMD j   | 0                | 0  | 1              | 1  | 0  | 1  | 1              | j1 | jo             | 0 | 6             | C<br>+j    | 1                           |                  | $(A) \leftarrow \rightarrow (M(DP))$ $(X) \leftarrow (X) EXOR(j)$ $j = 0 \text{ to } 3$ $(Y) \leftarrow (Y) - 1$                |
|                          | XAMI j   | 0                | 0  | 1              | 1  | 0  | 1  | 0              | j1 | jo             | 0 | 6             | 8<br>+j    | 1                           | 1                | $(A) \longleftrightarrow (M(DP))$ $(X) \longleftrightarrow (X) EXOR(j)$ $j = 0 \text{ to } 3$ $(Y) \longleftrightarrow (Y) + 1$ |

| Skip condition | Carry flag CY | Detailed description                                                                                                                                                                                                                                                                                                                                            |
|----------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -              | _             | After transferring the contents of M(DP) to register A, an exclusive OR operation is performed between register X and the value j in the immediate field, and stores the result in register X.                                                                                                                                                                  |
| -              | _             | After exchanging the contents of M(DP) with the contents of register A, an exclusive OR operation is performed between register X and the value j in the immediate field, and stores the result in register X.                                                                                                                                                  |
| (Y) = 15       | _             | After exchanging the contents of M(DP) with the contents of register A, an exclusive OR operation is performed between register X and the value j in the immediate field, and stores the result in register X. Subtracts 1 from the contents of register Y. As a result of subtraction, when the contents of register Y is 15, the next instruction is skipped. |
| (Y) = 0        | _             | After exchanging the contents of M(DP) with the contents of register A, an exclusive OR operation is performed between register X and the value j in the immediate field, and stores the result in register X. Adds 1 to the contents of register Y. As a result of addition, when the contents of register Y is 0, the next instruction is skipped.            |



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

## **MACHINE INSTRUCTIONS (CONTINUED)**

| Parameter            |          |    | Instruction code |    |                |    |    |                |    |                |   |      |             |                    | er of            |                                                                                                                                                                                                                                                                                             |
|----------------------|----------|----|------------------|----|----------------|----|----|----------------|----|----------------|---|------|-------------|--------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Type of instructions | Mnemonic | D8 | D7               | D6 | D <sub>5</sub> | D4 | Dз | D <sub>2</sub> | D1 | D <sub>0</sub> | 1 | adeo | cimal<br>on | Number of<br>words | Number of cycles | Function                                                                                                                                                                                                                                                                                    |
|                      | LA n     | 0  | 1                | 0  | 1              | 1  | nз | n2             | N1 | <b>n</b> o     | 0 | В    | n           | 1                  | 1                | (A) ← n<br>n = 0 to 15                                                                                                                                                                                                                                                                      |
|                      | TABP p   | 0  | 1                | 0  | 0              | 1  | рз | p2             | p1 | po             | 0 | 9    | p           | 1                  | 3                | $(SK(SP)) \leftarrow (PC)$<br>$(SP) \leftarrow (SP) + 1$<br>$(PCH) \leftarrow p$<br>$(PCL) \leftarrow (DR_2-DR_0, A_3-A_0)$<br>$(B) \leftarrow (ROM(PC))_7 \text{ to 4}$<br>$(A) \leftarrow (ROM(PC))_3 \text{ to 0}$<br>$(SP) \leftarrow (SP) - 1$<br>$(PC) \leftarrow (SK(SP))$<br>(Note) |
| tion                 | AM       | 0  | 0                | 0  | 0              | 0  | 1  | 0              | 1  | 0              | 0 | 0    | Α           | 1                  | 1                | $(A) \leftarrow (A) + (M(DP))$                                                                                                                                                                                                                                                              |
| Arithmetic operation | AMC      | 0  | 0                | 0  | 0              | 0  | 1  | 0              | 1  | 1              | 0 | 0    | В           | 1                  | 1                | $(A) \leftarrow (A) + (M(DP)) + (CY)$<br>$(CY) \leftarrow Carry$                                                                                                                                                                                                                            |
| Arithm               | A n      | 0  | 1                | 0  | 1              | 0  | nз | <b>n</b> 2     | N1 | no             | 0 | Α    | n           | 1                  | 1                | $(A) \leftarrow (A) + n$<br>n = 0  to  15                                                                                                                                                                                                                                                   |
|                      | sc       | 0  | 0                | 0  | 0              | 0  | 0  | 1              | 1  | 1              | 0 | 0    | 7           | 1                  | 1                | (CY) ← 1                                                                                                                                                                                                                                                                                    |
|                      | RC       | 0  | 0                | 0  | 0              | 0  | 0  | 1              | 1  | 0              | 0 | 0    | 6           | 1                  | 1                | (CY) ← 0                                                                                                                                                                                                                                                                                    |
|                      | szc      | 0  | 0                | 0  | 1              | 0  | 1  | 1              | 1  | 1              | 0 | 2    | F           | 1                  | 1                | (CY) = 0 ?                                                                                                                                                                                                                                                                                  |
|                      | СМА      | 0  | 0                | 0  | 0              | 1  | 1  | 1              | 0  | 0              | 0 | 1    | С           | 1                  | 1                | $(A) \leftarrow (\overline{A})$                                                                                                                                                                                                                                                             |
|                      | RAR      | 0  | 0                | 0  | 0              | 1  | 1  | 1              | 0  | 1              | 0 | 1    | D           | 1                  | 1                | CY A3A2A1A0                                                                                                                                                                                                                                                                                 |
|                      | LGOP     | 0  | 1                | 0  | 0              | 0  | 0  | 0              | 0  | 1              | 0 | 4    | 1           | 1                  | 1                | Logic operation instruction XOR, OR, AND                                                                                                                                                                                                                                                    |

Note: p is 0 to 15 for M34250E2, and p is 0 to 15 for M34250M2.

|                           | <b>-</b>      |                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Skip condition            | Carry flag CY | Detailed description                                                                                                                                                                                                                                                                                                                               |
| Continuous<br>description | _             | Loads the value n in the immediate field to register A.  When the LA instructions are continuously coded and executed, only the first LA instruction is executed and other LA instructions coded continuously are skipped.                                                                                                                         |
| _                         | _             | Transfers bits 7 to 4 to register B and bits 3 to 0 to register A. These bits 7 to 0 are the ROM pattern in address (DR <sub>2</sub> DR <sub>1</sub> DR <sub>0</sub> A <sub>3</sub> A <sub>2</sub> A <sub>1</sub> A <sub>0</sub> ) specified by registers A and D in page p. When this instruction is executed, 1 stage of stack register is used. |
| -                         | _             | Adds the contents of M(DP) to register A. Stores the result in register A. The contents of carry flag CY remains unchanged.                                                                                                                                                                                                                        |
| _                         | 0/1           | Adds the contents of M(DP) and carry flag CY to register A. Stores the result in register A and carry flag CY.                                                                                                                                                                                                                                     |
| Overflow = 0              | _             | Adds the value n in the immediate field to register A.  The contents of carry flag CY remains unchanged.  Skips the next instruction when there is no overflow as the result of operation.                                                                                                                                                         |
| -                         | 1             | Sets (1) to carry flag CY.                                                                                                                                                                                                                                                                                                                         |
| _                         | 0             | Clears (0) to carry flag CY.                                                                                                                                                                                                                                                                                                                       |
| (CY) = 0                  | _             | Skips the next instruction when the contents of carry flag CY is "0."                                                                                                                                                                                                                                                                              |
| _                         | -             | Stores the one's complement for register A's contents in register A.                                                                                                                                                                                                                                                                               |
| _                         | 0/1           | Rotates 1 bit of the contents of register A including the contents of carry flag CY to the right.                                                                                                                                                                                                                                                  |
| _                         | _             | Execute the logic operation selected by logic operation selection register LO between the contents of register A and port S, and stores the result in register A.                                                                                                                                                                                  |



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

## **MACHINE INSTRUCTIONS (CONTINUED)**

| Parameter            |          |    | Instruction code  D8 D7 D6 D5 D4 D3 D2 D1 D0  Hexadecima notation |                |                |            |            |                |                |                |     |              |             | oer of<br>rds   |                  |                                      |  |  |
|----------------------|----------|----|-------------------------------------------------------------------|----------------|----------------|------------|------------|----------------|----------------|----------------|-----|--------------|-------------|-----------------|------------------|--------------------------------------|--|--|
| Type of instructions | Mnemonic | D8 | D7                                                                | D <sub>6</sub> | D <sub>5</sub> | D4         | Dз         | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | Hex | ade<br>otati | cimal<br>on | Number of words | Number of cycles | Function                             |  |  |
|                      | SB j     | 0  | 0                                                                 | 1              | 0              | 1          | 1          | 1              | j1             | jo             | 0   | 5            | C<br>+j     | 1               | l                | (Mj(DP)) ← 1<br>j = 0 to 3           |  |  |
| Bit operation        | RB j     | 0  | 0                                                                 | 1              | 0              | 0          | 1          | 1              | j1             | jo             | 0   | 4            | C<br>+j     | 1               | 1                | (Mj(DP)) ← 0<br>j = 0 to 3           |  |  |
| Bit                  | SZB j    | 0  | 0                                                                 | 0              | 1              | 0          | 0          | 0              | j1             | <b>j</b> o     | 0   | 2            | j           | 1               | 1                | (Mj(DP)) = 0 ?<br>j = 0 to 3         |  |  |
| <u> </u>             | SEAM     | 0  | 0                                                                 | 0              | 1              | 0          | 0          | 1              | 1              | 0              | 0   | 2            | 6           | 1               | 1                | (A) = (M(DP)) ?                      |  |  |
| Comparison operation | SEA n    | 0  | 0                                                                 | 0              | 1              | 0          | 0          | 1              | 0              | 1              | 0   | 2            | 5           | 2               | 2                | (A) = n ?<br>n = 0 to 15             |  |  |
| ပို့ ငြ              |          | 0  | 1                                                                 | 0              | 1              | 1          | nз         | n2             | n1             | no             | 0   | В            | n           |                 |                  |                                      |  |  |
|                      | Ва       | 1  | 1                                                                 | <b>a</b> 6     | <b>a</b> 5     | <b>a</b> 4 | <b>a</b> 3 | <b>a</b> 2     | <b>a</b> 1     | <b>a</b> 0     | 1   | 8<br>+a      | а           | 1               | 1                | (PCL) ← a6-a0                        |  |  |
|                      | BL p, a  | 0  | 0                                                                 | 0              | 1              | 1          | рз         | p <sub>2</sub> | <b>p</b> 1     | <b>p</b> 0     | 0   | 3            | р           | 2               | 2                | (РСн) ← р<br>(РС∟) ← a6−a0<br>(Note) |  |  |
| Branch operation     |          | 1  | 1                                                                 | <b>a</b> 6     | <b>a</b> 5     | <b>a</b> 4 | <b>a</b> 3 | <b>a</b> 2     | <b>a</b> 1     | <b>a</b> 0     | 1   | 8<br>+a      | а           |                 |                  | (Note)                               |  |  |
| nch op               | ВА а     | 0  | 0                                                                 | 0              | 0              | 0          | 0          | 0              | 0              | 1              | 0   | 0            | 1           | 2               | 2                | (PCL) ← (a6–a4, A3–A0)               |  |  |
| Bra                  |          | 1  | 1                                                                 | <b>a</b> 6     | <b>a</b> 5     | <b>a</b> 4 | <b>a</b> 3 | <b>a</b> 2     | <b>a</b> 1     | <b>a</b> 0     | 1   | 8<br>+a      | а           |                 |                  |                                      |  |  |
|                      | BLA p, a | 0  | 0                                                                 | 0              | 0              | 1          | 0          | 0              | 0              | 0              | 0   | 1            | 0           | 2               | 2                | (РСн) ← р<br>(РС∟) ← (а6–а₄, Аз–А₀)  |  |  |
|                      |          | 1  | 1                                                                 | <b>a</b> 6     | <b>a</b> 5     | <b>a</b> 4 | рз         | p <sub>2</sub> | p <sub>1</sub> | p <sub>0</sub> | 1   | 8<br>+a      | р           |                 |                  | (Note)                               |  |  |

Note: p is 0 to 15 for M34250E2, and p is 0 to 15 for M34250M2.

|                              | 5          |                                                                                                                                                                                                                                                            |
|------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Skip condition               | Carry flag | Detailed description                                                                                                                                                                                                                                       |
| -                            | _          | Sets (1) the contents of bit j (bit specified by the value j in the immediate field) of M(DP).                                                                                                                                                             |
| -                            | _          | Clears (0) the contents of bit j (bit specified by the value j in the immediate field) of M(DP).                                                                                                                                                           |
| (Mj(DP)) = 0<br>j = 0  to  3 | _          | Skips the next instruction when the contents of bit j (bit specified by the value j in the immediate field) of M(DP) is "0."                                                                                                                               |
| (A) = (M(DP))                | -          | Skips the next instruction when the contents of register A is equal to the contents of M(DP).                                                                                                                                                              |
| (A) = n<br>n = 0 to 15       | _          | Skips the next instruction when the contents of register A is equal to the value n in the immediate field.                                                                                                                                                 |
| _                            | -          | Branch within a page : Branches to address a in the identical page.                                                                                                                                                                                        |
| -                            | _          | Branch out of a page : Branches to address a in page p.                                                                                                                                                                                                    |
| _                            | _          | Branch within a page: Branches to address (a <sub>6</sub> a <sub>5</sub> a <sub>4</sub> A <sub>3</sub> A <sub>2</sub> A <sub>1</sub> A <sub>0</sub> ) determined by replacing the low-order 4 bits of the address a with register A in the identical page. |
| _                            | _          | Branch out of a page: Branches to address (a <sub>6</sub> a <sub>5</sub> a <sub>4</sub> A <sub>3</sub> A <sub>2</sub> A <sub>1</sub> A <sub>0</sub> ) determined by replacing the low-order 4 bits of the address a with register A in page p.             |



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

## **MACHINE INSTRUCTIONS (CONTINUED)**

| Parameter            |           |    | Instruction code |                |                |            |            |                |                |                |   |              |             | ds der of          |                  | 3                                                                                                                           |  |
|----------------------|-----------|----|------------------|----------------|----------------|------------|------------|----------------|----------------|----------------|---|--------------|-------------|--------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------|--|
| Type of instructions | Mnemonic  | D8 | D7               | D <sub>6</sub> | D <sub>5</sub> | D4         | Дз         | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |   | ade<br>otati | cimal<br>on | Number of<br>words | Number of cycles | Function                                                                                                                    |  |
|                      | ВМ а      | 1  | 0                | <b>a</b> 6     | <b>a</b> 5     | <b>a</b> 4 | аз         | <b>a</b> 2     | aı             | <b>a</b> 0     | 1 | а            | а           | 1                  | 1                | $(SK(SP)) \leftarrow (PC)$<br>$(SP) \leftarrow (SP) + 1$<br>$(PCH) \leftarrow 2$<br>$(PCL) \leftarrow a_6-a_0$              |  |
| Subroutine operation | BML p, a  | 0  | 0                | 1              | 1              | 1          | рз         | p <sub>2</sub> | p <sub>1</sub> | po             | 0 | 7            | р           | 2                  | 2                | $(SK(SP)) \leftarrow (PC)$<br>$(SP) \leftarrow (SP) + 1$<br>$(PCH) \leftarrow p$                                            |  |
| broutine             |           | 1  | 0                | <b>a</b> 6     | <b>a</b> 5     | <b>a</b> 4 | <b>a</b> 3 | <b>a</b> 2     | <b>a</b> 1     | <b>a</b> 0     | 1 | а            | а           |                    |                  | (PCL) ← a6-a0<br>(Note)                                                                                                     |  |
| Su                   | BMLA p, a |    | 0                | 1              | 0              | 1          | 0          | 0              | 0              | 0              |   | 5            |             | 2                  | 2                | $(SK(SP)) \leftarrow (PC)$<br>$(SP) \leftarrow (SP) + 1$                                                                    |  |
|                      |           | 1  | 0                | <b>a</b> 6     | <b>a</b> 5     | <b>a</b> 4 | рз         | p <sub>2</sub> | p <sub>1</sub> | p <sub>0</sub> | 1 | а            | р           |                    |                  | (PC <sub>H</sub> ) ← p<br>(PC <sub>L</sub> ) ← (a <sub>6</sub> –a <sub>4</sub> , A <sub>3</sub> –A <sub>0</sub> )<br>(Note) |  |
| ion                  | RTI       | 0  | 0                | 1              | 0              | 0          | 0          | 1              | 1              | 0              | 0 | 4            | 6           | 1                  | 1                | $(PC) \leftarrow (SK(SP))$<br>$(SP) \leftarrow (SP) - 1$                                                                    |  |
| Return operation     | RT        | 0  | 0                | 1              | 0              | 0          | 0          | 1              | 0              | 0              | 0 | 4            | 4           | 1                  | 2                | $(PC) \leftarrow (SK(SP))$<br>$(SP) \leftarrow (SP) - 1$                                                                    |  |
| Re                   | RTS       | 0  | 0                | 1              | 0              | 0          | 0          | 1              | 0              | 1              | 0 | 4            | 5           | 1                  | 2                | $(PC) \leftarrow (SK(SP))$<br>$(SP) \leftarrow (SP) - 1$                                                                    |  |
| on                   | DI        | 0  | 0                | 0              | 0              | 0          | 0          | 1              | 0              | 0              | 0 | 0            | 4           | 1                  | 1                | (INTE) ← 0                                                                                                                  |  |
| operati              | EI        | 0  | 0                | 0              | 0              | 0          | 0          | 1              | 0              | 1              | 0 | 0            | 5           | 1                  | 1                | (INTE) ← 1                                                                                                                  |  |
| Interrupt operation  | SNZ0      | 0  | 1                | 0              | 0              | 0          | 1          | 1              | 1              | 1              | 0 | 8            | F           | 1                  | 1                | (EXF0) = 1 ? After skipping the next instruction (EXF0) ← 0                                                                 |  |

Note: p is 0 to 15 for M34250E2, and p is 0 to 15 for M34250M2.

| Skip condition      | Carry flag CY | Detailed description                                                                                                                                                                                                                      |
|---------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _                   | _             | Call the subroutine in page 2 : Calls the subroutine at address a in page 2.                                                                                                                                                              |
|                     |               |                                                                                                                                                                                                                                           |
| _                   | _             | Call the subroutine : Calls the subroutine at address a in page p.                                                                                                                                                                        |
| _                   | _             | Call the subroutine: Calls the subroutine at address (a6 a5 a4 A3 A2 A1 A0) determined by replacing the low-order 4 bits of address a with register A in page p.                                                                          |
| _                   | _             | Returns from interrupt service routine to main routine.  Returns each value of data pointer (X, Y), carry flag, skip status, NOP mode status by the continuous description of the LA/LXY instruction to the states just before interrupt. |
| -                   | _             | Returns from subroutine to the routine called the subroutine.                                                                                                                                                                             |
| Skip at uncondition | -             | Returns from subroutine to the routine called the subroutine, and skips the next instruction at uncondition.                                                                                                                              |
| _                   | -             | Clears (0) to the interrupt enable flag INTE, and disables the interrupt.                                                                                                                                                                 |
| -                   | -             | Sets (1) to the interrupt enable flag INTE, and enables the interrupt.                                                                                                                                                                    |
| (EXF0) = 1          | _             | Skips the next instruction when the contents of EXF0 flag is "1."  After skipping, clears the EXF0 flag.                                                                                                                                  |

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

## MACHINE INSTRUCTIONS (CONTINUED)

| Parameter              |          |    |    |                |                | lr | nstru | ıctio          | n co           | de             |                      | er of              | er of            |                                                                                                                      |  |
|------------------------|----------|----|----|----------------|----------------|----|-------|----------------|----------------|----------------|----------------------|--------------------|------------------|----------------------------------------------------------------------------------------------------------------------|--|
| Type of instructions   | Mnemonic | D8 | D7 | D <sub>6</sub> | D <sub>5</sub> | D4 | Дз    | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | Hexadecimal notation | Number of<br>words | Number of cycles | Function                                                                                                             |  |
|                        | TAB1     | 0  | 1  | 0              | 0              | 0  | 1     | 0              | 1              | 0              | 0 8 A                | 1                  | 1                | (B) ← (T17–T14)<br>(A) ← (T13–T10)                                                                                   |  |
| Timer operation        | T1AB     | 0  | 1  | 0              | 0              | 0  | 0     | 1              | 0              | 1              | 0 8 5                | 1                  | l                | $(R17-R14) \leftarrow (B)$<br>$(T17-T14) \leftarrow (B)$<br>$(R13-R10) \leftarrow (A)$<br>$(T13-T10) \leftarrow (A)$ |  |
| Timer                  | SNZ1     | 0  | 1  | 0              | 0              | 0  | 1     | 1              | 0              | 0              | 0 8 C                | 1                  |                  | $(T15-T10) \leftarrow (A)$<br>(T1F) = 1?<br>After skipping the next instruction<br>$(T1F) \leftarrow 0$              |  |
|                        | CLD      | 0  | 0  | 0              | 0              | 1  | 0     | 0              | 0              | 1              | 0 1 1                | 1                  | 1                | (D) ← 1                                                                                                              |  |
| ration                 | RD       | 0  | 0  | 0              | 0              | 1  | 0     | 1              | 0              | 0              | 0 1 4                | 1                  | 1                | $(D(Y)) \leftarrow 0$<br>(Y) = 0 to 3                                                                                |  |
| Input/Output operation | SD       | 0  | 0  | 0              | 0              | 1  | 0     | 1              | 0              | 1              | 0 1 5                | 1                  | 1                | $(D(Y)) \leftarrow 1$ $(Y) = 0 \text{ to } 3$                                                                        |  |
| Input/O                | SZD      | 0  | 0  | 0              | 1              | 0  | 0     | 1              | 0              | 0              | 0 2 4                | 2                  | 2                | (D(Y)) = 0 ?<br>(Y) = 0 to 3                                                                                         |  |
|                        |          | 0  | 0  | 0              | 1              | 0  | 1     | 0              | 1              | 1              | 0 2 B                |                    |                  |                                                                                                                      |  |

| Skip condition             | Carry flag CY | Detailed description                                                                                      |
|----------------------------|---------------|-----------------------------------------------------------------------------------------------------------|
| -                          | _             | Transfers the contents of timer 1 to registers A and B.                                                   |
| _                          | _             | Transfers the contents of registers A and B to timer 1 and timer 1 reload register.                       |
| (T1F) = 1                  | _             | Skips the next instruction when the contents of T1F flag is "1."  After skipping, clears (0) to T1F flag. |
| _                          | -             | Sets (1) to port D (high-impedance state).                                                                |
| _                          | _             | Clears (0) to a bit of port D specified by register Y.                                                    |
| _                          | _             | Sets (1) to a bit of port D specified by register Y (high-impedance state).                               |
| (D(Y)) = 0<br>(Y) = 0 to 3 | _             | Skips the next instruction when a bit of port D specified by register Y is "0."                           |

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

## MACHINE INSTRUCTIONS (CONTINUED)

| Parameter              |          |    | Instruction code |                |                |    |    |                |    |                |      |   |             | er of              | er of              |                                                      |
|------------------------|----------|----|------------------|----------------|----------------|----|----|----------------|----|----------------|------|---|-------------|--------------------|--------------------|------------------------------------------------------|
| Type of instructions   | Mnemonic | D8 | D7               | D <sub>6</sub> | D <sub>5</sub> | D4 | Dз | D <sub>2</sub> | D1 | D <sub>0</sub> | Hexa |   | cimal<br>on | Number of<br>words | Number c<br>cycles | Function                                             |
|                        | OFA      | 0  | 1                | 0              | 0              | 0  | 0  | 1              | 0  | 0              | 0    | 8 | 4           | 1                  | 1                  | $(F) \leftarrow (A_1, A_0)$                          |
|                        | IAF      | 0  | 0                | 1              | 0              | 1  | 0  | 1              | 1  | 0              | 0    | 5 | 6           | 1                  | 1                  | $(A_1, A_0) \leftarrow (F), (A_3, A_2) \leftarrow 0$ |
|                        | OGA      | 0  | 1                | 0              | 0              | 0  | 0  | 0              | 0  | 0              | 0    | 8 | 0           | 1                  | 1                  | $(G) \leftarrow (A)$                                 |
|                        | IAG      | 0  | 0                | 0              | 1              | 0  | 1  | 0              | 0  | 0              | 0    | 2 | 8           | 1                  | 1                  | $(A) \leftarrow (G)$                                 |
| ration                 | OSA      | 0  | 0                | 0              | 0              | 1  | 1  | 0              | 1  | 1              | 0    | 1 | В           | 1                  | 1                  | $(S) \leftarrow (A)$                                 |
| out ope                | IAS      | 0  | 0                | 1              | 0              | 1  | 0  | 1              | 0  | 1              | 0    | 5 | 5           | 1                  | 1                  | $(A) \leftarrow (S)$                                 |
| Input/Output operation | OKA      | 0  | 1                | 0              | 0              | 0  | 0  | 0              | 0  | 1              | 0    | 8 | 1           | 1                  | 1                  | $(K) \leftarrow (A_0)$                               |
| dul                    | IAK      | 0  | 0                | 1              | 0              | 1  | 0  | 1              | 1  | 1              | 0    | 5 | 7           | 1                  | 1                  | $(A_0) \leftarrow (K), (A_3-A_1) \leftarrow 0$       |
|                        | SCP      | 0  | 1                | 0              | 0              | 0  | 0  | 0              | 1  | 0              | 0    | 8 | 2           | 1                  | 1                  | (C) ← 1                                              |
|                        | RCP      | 0  | 1                | 0              | 0              | 0  | 0  | 0              | 1  | 1              | 0    | 8 | 3           | 1                  | 1                  | (C) ← 0                                              |
|                        | SNZCP    | 0  | 1                | 0              | 0              | 0  | 1  | 1              | 0  | 1              | 0    | 8 | D           | 1                  | 1                  | (C) = 1 ?                                            |
|                        | NOP      | 0  | 0                | 0              | 0              | 0  | 0  | 0              | 0  | 0              | 0    | 0 | 0           | 1                  | 1                  | (PC) ← (PC) + 1                                      |
|                        | POF      | 0  | 0                | 0              | 0              | 0  | 1  | 1              | 0  | 1              | 0    | 0 | D           | 1                  | 1                  | RAM back-up                                          |
|                        | SNZP     | 0  | 0                | 0              | 0              | 0  | 0  | 0              | 1  | 1              | 0    | 0 | 3           | 1                  | 1                  | (P) = 1 ?                                            |
| Other operation        | TLOA     | 0  | 0                | 1              | 0              | 1  | 1  | 0              | 0  | 0              | 0    | 5 | 8           | 1                  | 1                  | $(LO) \leftarrow (A_1, A_0)$                         |
| ther o                 | TV1A     | 0  | 1                | 0              | 0              | 0  | 0  | 1              | 1  | 0              | 0    | 8 | 6           | 1                  | 1                  | (V1) ← (A)                                           |
|                        | TAV1     | 0  | 1                | 0              | 0              | 0  | 1  | 0              | 0  | 0              | 0    | 8 | 8           | 1                  | 1                  | (A) ← (V1)                                           |
|                        | TK0A     | 0  | 1                | 0              | 0              | 0  | 0  | 1              | 1  | 1              | 0    | 8 | 7           | 1                  | 1                  | (K0) ← (A)                                           |
|                        | TAK0     | 0  | 1                | 0              | 0              | 0  | 1  | 0              | 0  | 1              | 0    | 8 | 9           | 1                  | 1                  | (A) ← (K0)                                           |
|                        | TPU0A    | 0  | 1                | 0              | 0              | 0  | 1  | 0              | 1  | 1              | 0    | 8 | В           | 1                  | 1                  | (PU0) ← (A)                                          |

| Skip condition | Carry flag CY | Detailed description                                                                     |
|----------------|---------------|------------------------------------------------------------------------------------------|
| _              | _             | Outputs the contents of register A to port F.                                            |
| _              | _             | Transfers the contents of port F to register A.                                          |
| _              | _             | Outputs the contents of register A to port G.                                            |
| -              | _             | Transfers the contents of port G to register A.                                          |
| _              | _             | Outputs the contents of register A to port S.                                            |
| _              | _             | Transfers the contents of port S to register A.                                          |
| _              | _             | Outputs the contents of register A to port K.                                            |
| _              | _             | Transfers the contents of port K to register A.                                          |
| _              | _             | Sets (1) to port C.                                                                      |
| _              | _             | Clears (0) to port C.                                                                    |
| (C) = 1        | _             | Skips the next instruction when the contents of port C is "1."                           |
| -              | -             | No operation                                                                             |
| -              | _             | Puts the system in RAM back-up state.                                                    |
| (P) = 1        | _             | Skips the next instruction when P flag is "1." After skipping, P flag remains unchanged. |
| _              | _             | Transfers the contents of register A to the logic operation selection register LO.       |
| _              | _             | Transfers the contents of register A to register V1.                                     |
| -              | _             | Transfers the contents of register V1 to register A.                                     |
| _              | _             | Transfers the contents of register A to register K0.                                     |
| _              | _             | Transfers the contents of register K0 to register A.                                     |
| _              | _             | Transfers the contents of register A to register PU0.                                    |

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **CONTROL REGISTERS**

| Timer control register V1              |                                                                |                 | at                                          | reset: 00002                                                   | at RAM back-up : 00002          | R/W |  |  |  |
|----------------------------------------|----------------------------------------------------------------|-----------------|---------------------------------------------|----------------------------------------------------------------|---------------------------------|-----|--|--|--|
| 1/4                                    | 0.7                                                            | (               | 0                                           | Port G <sub>1</sub> (I/O)                                      |                                 |     |  |  |  |
| V13 G1/Tουτ pin function selection bit |                                                                |                 | 1                                           | Touт pin (output) / port G1(input)                             |                                 |     |  |  |  |
|                                        |                                                                | (               | 0                                           | Prescaler stop (initial state) / timer 1 stop (state retained) |                                 |     |  |  |  |
| V12                                    | Prescaler/timer 1 operation start bit                          | •               | 1 Prescaler/timer 1 operation               |                                                                |                                 |     |  |  |  |
| V1 <sub>1</sub>                        | Times 4 interment enable hit                                   | (               | 0                                           | Interrupt disabled (SNZ1 instruction is valid)                 |                                 |     |  |  |  |
| V I 1                                  | Timer 1 interrupt enable bit                                   |                 | 1                                           | Interrupt enabled (S                                           | SNZ1 instruction is invalid)    |     |  |  |  |
| \/4 -                                  | External interrupt anable bit                                  | (               | )                                           | Interrupt disabled (                                           | SNZ0 instruction is valid)      |     |  |  |  |
| V10                                    | External interrupt enable bit                                  |                 | 1                                           | Interrupt enabled (                                            | SNZ0 instruction is invalid)    |     |  |  |  |
| ŀ                                      | Key-on wakeup control register K0                              |                 | at                                          | reset: 00002                                                   | at RAM back-up : state retained | R/W |  |  |  |
| K03                                    | Prescaler dividing ratio selection bit                         | (               | )                                           | Instruction clock div                                          | vided by 4                      |     |  |  |  |
| NU3                                    | Prescaler dividing fallo selection bit                         | •               | 1                                           | Instruction clock div                                          | vided by 512                    |     |  |  |  |
|                                        | Interrupt valid waveform for INT pin/                          | (               | )                                           | Rising waveform ("                                             | L" → "H")                       |     |  |  |  |
| K0 <sub>2</sub>                        | key-on wakeup valid waveform selection                         |                 |                                             |                                                                |                                 |     |  |  |  |
| NO2                                    | bit (Note 2)                                                   |                 | 1                                           | Falling waveform ("H" $\rightarrow$ "L")                       |                                 |     |  |  |  |
| 1/0                                    | Dente Co. College on suppose a sector leit                     | (               | 0                                           | Key-on wakeup not used                                         |                                 |     |  |  |  |
| K0 <sub>1</sub>                        | Ports G <sub>1</sub> –G <sub>3</sub> key-on wakeup control bit |                 | 1                                           | Key-on wakeup used ("L" level recognized)                      |                                 |     |  |  |  |
| K00                                    | Ports S <sub>0</sub> –S <sub>3</sub> key-on wakeup control bit | (               | 0 Key-on wakeup not used                    |                                                                |                                 |     |  |  |  |
| NO0                                    | Forts 30–33 key-on wakeup control bit                          | •               | 1 Key-on wakeup used ("L" level recognized) |                                                                |                                 |     |  |  |  |
|                                        | Pull-up control register PU0                                   | at reset : 002  |                                             | t reset : 002                                                  | at RAM back-up : state retained | W   |  |  |  |
| PU0 <sub>1</sub>                       | Ports C and K                                                  | 0 Pull-up tra   |                                             | Pull-up transistor O                                           | sistor OFF                      |     |  |  |  |
| P 001                                  | pull-up transistor control bit                                 | ·               | 1 Pull-up transistor ON                     |                                                                |                                 |     |  |  |  |
| PU0o                                   | Ports G <sub>0</sub> –G <sub>3</sub>                           | 0               | 0 Pull-up transistor OFF                    |                                                                | )FF                             |     |  |  |  |
| F 000                                  | pull-up transistor control bit                                 | Ĺ               | 1                                           | Pull-up transistor ON                                          |                                 |     |  |  |  |
| Logic operation selection register LO  |                                                                | at reset : 002  |                                             | t reset : 002                                                  | at RAM back-up : 002            | W   |  |  |  |
|                                        |                                                                | LO <sub>1</sub> | LO <sub>0</sub>                             |                                                                | Functions                       |     |  |  |  |
| LO <sub>1</sub>                        |                                                                | 0               | 0                                           | XOR operation                                                  |                                 |     |  |  |  |
|                                        | Logic operation function selection bits                        | 0               | 1                                           | OR operation                                                   |                                 |     |  |  |  |
| $LO_0$                                 |                                                                | 1               | 0                                           | AND operation                                                  |                                 |     |  |  |  |
|                                        |                                                                |                 | 1                                           | Not available                                                  |                                 |     |  |  |  |

Notes 1: "R" represents read enabled, and "W" represents write enabled.



<sup>2:</sup> Set a value to the bit 2 of register K0, and execute the SNZ0 instruction to clear the EXF0 flag to "0" after executing at least one instruction. According to the input state of Go/INT pin, the external interrupt request flag (EXF0) may be set to "1" when the interrupt valid waveform is changed.

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

#### **ABSOLUTE MAXIMUM RATINGS**

| Symbol | Parameter                                                                                                                | Conditions         | Ratings         | Unit |
|--------|--------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------|------|
| VDD    | Supply voltage                                                                                                           |                    | -0.3 to 7.0     | V    |
| Vı     | Input voltage XIN, G0-G3, D2/C, D3/K                                                                                     |                    | -0.3 to VDD+0.3 | V    |
| Vı     | Input voltage F <sub>0</sub> , F <sub>1</sub> , S <sub>0</sub> –S <sub>3</sub> , D <sub>0</sub> , D <sub>1</sub> , RESET |                    | -0.3 to 8.0     | V    |
| Vo     | Output voltage XouT                                                                                                      |                    | -0.3 to VDD+0.3 | V    |
| Vo     | Output voltage F <sub>0</sub> , F <sub>1</sub> , S <sub>0</sub> –S <sub>3</sub> , D <sub>0</sub> , D <sub>1</sub>        | Output transistors | -0.3 to 8.0     | V    |
| Vo     | Output voltage G <sub>0</sub> –G <sub>3</sub> , D <sub>2</sub> /C, D <sub>3</sub> /K                                     | in cut-off state   | -0.3 to VDD+0.3 | V    |
| Pd     | Power dissipation                                                                                                        | Ta = 25 °C         | 300             | mW   |
| Topr   | Operating temperature range                                                                                              |                    | -20 to 85       | °C   |
| Tstg   | Storage temperature range                                                                                                |                    | -40 to 125      | °C   |

#### RECOMMENDED OPERATING CONDITIONS

(Ta = -20 °C to 85 °C, VDD = 2.2 V to 5.5 V, unless otherwise noted)

| Symbol          | Parameter                                                  | Conditions                                          |         | Unit |         |     |
|-----------------|------------------------------------------------------------|-----------------------------------------------------|---------|------|---------|-----|
| Syllibol        | Parameter                                                  | Conditions                                          | Min.    | Тур. | Max.    |     |
| VDD             | Supply voltage                                             | $0.4 \text{ MHz} \le f(X_{IN}) \le 4.4 \text{ MHz}$ | 4.5     | 5.0  | 5.5     | V   |
|                 |                                                            | $0.4 \text{ MHz} \le f(X_{IN}) \le 1.1 \text{ MHz}$ | 2.2     |      | 5.5     | V   |
| VRAM            | RAM back-up voltage (at RAM back-up mode)                  |                                                     | 2.0     |      | 5.5     | V   |
| Vss             | Supply voltage                                             |                                                     |         | 0    |         | V   |
| Vін             | "H" level input voltage Fo, F1, Do, D1                     |                                                     | 0.7Vdd  |      | 7       | V   |
| Vін             | "H" level input voltage Go-G3, D2, D3                      |                                                     | 0.7Vdd  |      | VDD     | V   |
| Vін             | "H" level input voltage INT                                |                                                     | 0.85Vpd |      | VDD     | V   |
| Vін             | "H" level input voltage C, K                               | VDD = 4.5 V to 5.5 V                                | 0.5VDD  |      | VDD     | V   |
|                 |                                                            | VDD = 2.2 V to 5.5 V                                | 0.7VDD  |      | VDD     | V   |
| ViH             | "H" level input voltage So-S3                              | VDD = 4.5 V to 5.5 V                                | 0.4Vpd  |      | 7       | V   |
|                 |                                                            | VDD = 2.2 V to 5.5 V                                | 0.6Vpd  |      | 7       | V   |
| ViH             | "H" level input voltage RESET                              |                                                     | 0.85Vpd |      | 7       | V   |
| VIL             | "L" level input voltage C, K                               |                                                     | 0       |      | 0.16Vpd | V   |
| VIL             | "L" level input voltage S <sub>0</sub> –S <sub>3</sub>     |                                                     | 0       |      | 0.2Vdd  | V   |
| VIL             | "L" level input voltage Fo, F1, G0-G3, D0-D3               |                                                     | 0       |      | 0.3Vpd  | V   |
| VIL             | "L" level input voltage INT                                |                                                     | 0       |      | 0.15Vpd | V   |
| VIL             | "L" level input voltage RESET                              |                                                     | 0       |      | 0.1VDD  | V   |
| loL(peak)       | "L" level peak output current                              |                                                     |         |      | 24      | mA  |
|                 | Fo, F1, S0-S3, D0, D1, D2/C, D3/K                          |                                                     |         |      |         |     |
| loL(peak)       | "L" level peak output current Go, G1/Tout, G2, G3          |                                                     |         |      | 10      | mA  |
| loL(avg)        | "L" level average output current                           | (Note 1)                                            |         |      | 12      | mA  |
|                 | Fo, F1, S0-S3, D0, D1, D2/C, D3/K                          |                                                     |         |      |         |     |
| loL(avg)        | "L" level average output current Go, G1/Touт, G2, G3       | (Note 1)                                            |         |      | 5       | mA  |
| f(XIN)          | System clock frequency (Note 2)                            | VDD = 4.5 V to 5.5 V                                | 0.4     | 4.0  | 4.4     | MHz |
|                 |                                                            | VDD = 2.2 V to 5.5 V                                | 0.4     | 1.0  | 1.1     |     |
| $\Delta f(XIN)$ | Frequency error (errors of external capacitor and resistor | VDD = 5 V ±10 %                                     |         |      | ±17     | %   |
|                 | not included)                                              | Ta = 25 °C [reference]                              |         |      |         |     |
|                 | Note: Use the 30 pF capacitor externally and enable the    | (-20 °C to 85 °C)                                   |         |      |         |     |
|                 | change of frequency by external resistor.                  | VDD = 3 V ±10 %                                     |         |      | ±17     |     |
|                 |                                                            | Ta = 25 °C [reference]                              |         |      |         |     |
|                 |                                                            | (-20 °C to 85 °C)                                   |         |      |         |     |

Notes 1: Keep the total currents of IoL(avg) for ports So-S3, Do, D1, D2/C, D3/K to 50 mA or less.

Keep the total currents of loL(avg) for ports  $F_0$ ,  $F_1$ ,  $G_0$ ,  $G_2$ ,  $G_3$  and  $G_1/T_0 \cup T$  pin to 30 mA or less.

2: The system clock frequency is affected by the external capacitor, resistor and LSI. Accordingly, set the constants so as not to exceed the frequency limits.

Be careful about the input waveform when using the external clock. Refer to the notes on use.



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **ELECTRICAL CHARACTERISTICS**

(Ta = -20 °C to 85 °C, V<sub>DD</sub> = 2.2 V to 5.5 V, unless otherwise noted)

| Cumbal            | Parameter                                                                                                                                  |                                                       | Test conditions     |                  | Limits |      |      | 11.36 |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|---------------------|------------------|--------|------|------|-------|
| Symbol            |                                                                                                                                            |                                                       |                     |                  | Min.   | Тур. | Max. | Unit  |
| Vol               | "L" level output voltage                                                                                                                   |                                                       | VDD = 5 V           | IoL = 12 mA      |        |      | 2    | V     |
|                   | Fo, F1, S0-S3, D                                                                                                                           | Do, D1, D2/C, D3/K                                    | $V_{DD} = 3 V$      | IoL = 6 mA       |        |      | 0.9  | V     |
| Vol               | "L" level output                                                                                                                           | voltage                                               | VDD = 5 V           | IoL = 5 mA       |        |      | 2    | V     |
|                   | Go, G1/Tout, G2                                                                                                                            | 2, <b>G</b> 3                                         | VDD = 3 V           | IoL = 2 mA       |        |      | 0.9  | V     |
| Іін               | "H" level input of                                                                                                                         | current                                               | Vı = 7 V            |                  |        |      | 1    | μΑ    |
|                   | Fo, F1, S0-S3, D                                                                                                                           | Do, D1, RESET                                         |                     |                  |        |      |      |       |
| Іін               | "H" level input of Go/INT, G1, G2,                                                                                                         | current<br>G3, D2/C, D3/K                             | VI = VDD            |                  |        |      | 1    | μΑ    |
| lıL               | "L" level input c                                                                                                                          | urrent                                                | VI = 0 V (No        | ote)             |        |      | -1   | μΑ    |
|                   | F <sub>0</sub> , F <sub>1</sub> , S <sub>0</sub> –S <sub>3</sub> , D <sub>0</sub> , D <sub>1</sub> , D <sub>2</sub> /C, D <sub>3</sub> /K, |                                                       |                     |                  |        |      |      |       |
|                   | G <sub>0</sub> /INT, G <sub>1</sub> , G <sub>2</sub> , G <sub>3</sub> , RESET                                                              |                                                       |                     |                  |        |      |      |       |
| Іохн              | Output current at off-state                                                                                                                |                                                       | Vo = 7 V            |                  |        |      | 1    | μΑ    |
|                   | F <sub>0</sub> , F <sub>1</sub> , S <sub>0</sub> –S <sub>3</sub> , D <sub>0</sub> , D <sub>1</sub>                                         |                                                       |                     |                  |        |      |      |       |
| Іохн              | Output current at off-state                                                                                                                |                                                       | Vo = VDD            |                  |        |      | 1    | μΑ    |
|                   | G <sub>0</sub> , G <sub>1</sub> /T <sub>0</sub> UT, G <sub>2</sub> , G <sub>3</sub> , D <sub>2</sub> /C, D <sub>3</sub> /K                 |                                                       |                     |                  |        |      |      |       |
| IDD               | Supply current                                                                                                                             | at active mode                                        | VDD = 5 V           | f(XIN) = 4.0 MHz |        | 1.5  | 5    | mA    |
|                   |                                                                                                                                            |                                                       | $V_{DD} = 3 V$      | f(XIN) = 1.0 MHz |        | 0.3  | 1    | mA    |
|                   |                                                                                                                                            | at RAM back-up mode                                   | Ta = 25 °C          |                  |        | 0.1  | 1    | μΑ    |
|                   |                                                                                                                                            |                                                       | VDD = 5 V           |                  |        |      | 10   | μΑ    |
|                   |                                                                                                                                            |                                                       | VDD = 3 V           |                  |        |      | 6    | μΑ    |
| Rpu               | Pull-up transisto                                                                                                                          | or                                                    | VDD = 5 V, VI = 0 V |                  | 5      | 11   | 25   | kΩ    |
|                   | Go/INT, G <sub>1</sub> , G <sub>2</sub> ,                                                                                                  | G <sub>3</sub> , D <sub>2</sub> /C, D <sub>3</sub> /K |                     |                  |        |      |      |       |
| $V_{T+} - V_{T-}$ | Hysteresis INT                                                                                                                             |                                                       |                     |                  |        | 0.3  |      | V     |
| VT+ - VT-         | Hysteresis So-S                                                                                                                            | <b>S</b> 3                                            | VDD = 5 V           |                  | 0.1    |      |      | V     |
| VT+ - VT-         | Hysteresis RES                                                                                                                             | ET                                                    | VDD = 5 V           |                  |        | 1.8  |      | V     |
|                   |                                                                                                                                            |                                                       |                     |                  |        | 0.7  |      | V     |

Note: In this case, the pull-up transistors for Go/INT pin and ports G<sub>1</sub>, G<sub>2</sub>, G<sub>3</sub>, D<sub>2</sub>/C and D<sub>3</sub>/K are not selected.



SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

### **BASIC TIMING DIAGRAM**

|                      | Machine cycle                                                                                                                                                | Mi             |                | М              | i+1 |                |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|----------------|-----|----------------|
| Parameter            | State Pin name                                                                                                                                               | T <sub>4</sub> | T <sub>1</sub> | T <sub>2</sub> | Тз  | T <sub>4</sub> |
| Clock                | Xin                                                                                                                                                          |                |                |                |     |                |
| Ports D, C, K output | D <sub>0</sub> ,D <sub>1</sub><br>D <sub>2</sub> /C,D <sub>3</sub> /K                                                                                        |                |                |                |     |                |
| Ports D, C, K input  | D <sub>0</sub> ,D <sub>1</sub><br>D <sub>2</sub> /C,D <sub>3</sub> /K                                                                                        |                |                |                |     |                |
| Ports F, G, S output | F <sub>0</sub> ,F <sub>1</sub><br>G <sub>0</sub> /INT,G <sub>1</sub> /T <sub>0</sub> UT<br>G <sub>2</sub> , G <sub>3</sub><br>S <sub>0</sub> –S <sub>3</sub> |                |                |                |     |                |
| Ports F, G, S input  | F <sub>0</sub> ,F <sub>1</sub><br>G <sub>0</sub> /INT,G <sub>1</sub> /T <sub>0</sub> UT<br>G <sub>2</sub> , G <sub>3</sub><br>S <sub>0</sub> –S <sub>3</sub> |                |                |                |     |                |
| Interrupt input      | Go/INT                                                                                                                                                       | X              |                |                |     |                |

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

#### **BUILT-IN PROM VERSION**

In addition to the mask ROM versions, the 4250 Group has the One Time PROM versions whose PROMs can only be written to and not be erased.

The built-in PROM version has functions similar to those of the mask ROM versions, but it has PROM mode that enables writing to built-in PROM.

Table 15 shows the product of built-in PROM version. Figure 31 and 32 show the pin configurations of built-in PROM versions. The One Time PROM version has pin-compatibility with the mask ROM version.

Table 15 Product of built-in PROM version

| Product          | PROM size<br>(X 9 bits) | RAM size<br>(X 4 bits) | Package | ROM type                                                                          |
|------------------|-------------------------|------------------------|---------|-----------------------------------------------------------------------------------|
| M34250E2-XXXFP * | 2048 words              | 64 words               | 20P2N-A | One Time PROM [shipped after writing] (shipped after writing and test in factory) |
| M34250E2FP*      |                         |                        |         | One Time PROM [shipped in blank]                                                  |

<sup>\*:</sup> Under development



Fig. 31 Pin configuration of built-in PROM version



Fig. 32 Pin configuration of built-in PROM version (continued)

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

#### (1) PROM mode

The 4250 Group has a function to serially input/output the command codes, addresses, and data required for operation (e.g. read and program) on the built-in PROM using only a few pins. This mode can be selected by setting pins SDA (serial data input/output), SCLK (serial clock input), and  $\overline{PGM}$  to "H" after connecting wires as shown in Figure 32 and powering on the VDD pin, and then applying 12 V to the VPP pin.

In the PROM mode, three types of software commands (read, program, and program verify) can be used.

Clock-synchronous serial I/O is used, beginning from the LSB (LSB first). Use the special-purpose serial programmer when performing serial read/program.

Refer to the Mitsubishi Data Book "DEVELOPMENT SUPPORT TOOLS FOR MICROCOMPUTERS" about the serial programmer (serial programmer and control software, etc.) for the Mitsubishi single-chip microcomputers.

#### (2) Notes on handling

- ① A high-voltage is used for writing. Take care that overvoltage is not applied. Take care especially at turning on the power.
- ② For the One Time PROM version shipped in blank, Mitsubishi Electric corp. does not perform PROM writing test and screening in the assembly process and following processes. In order to improve reliability after writing, performing writing and test according to the flow shown in Figure 33 before using is recommended (Products shipped in blank: PROM contents is not written in factory when shipped)



Fig. 33 Flow of writing and test of the product shipped in



#### **MITSUBISHI MICROCOMPUTERS**

## **4250 Group**

SINGLE-CHIP 4-BIT CMOS MICROCOMPUTER

#### Keep safety first in your circuit designs!

Mitsubishi Electric Corporation puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage. Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of non-flammable material or (iii) prevention against any malfunction or mishap.

#### Notes regarding these materials -

- These materials are intended as a reference to assist our customers in the selection of the Mitsubishi semiconductor product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Mitsubishi Electric Corporation or a third party.

  Mitsubishi Electric Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts or circuit application examples contained in these materials.

  All information contained in these materials, including product data, diagrams and charts, represent information on products at the time of publication of these materials, and are subject to change by Mitsubishi Electric Corporation without notice due to product improvements or other reasons. It is therefore recommended that customers contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for the latest product information before purchasing a product listed herein.

  Mitsubishi Electric Corporations semiconductors are not designed or repartiseful to repart that is used under circumstances in which bumps life is potentially at stake. Please contact
- Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use.

  The prior written approval of Mitsubishi Electric Corporation is necessary to reprint or reproduce in whole or in part these materials.

  If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination.

- Any diversion or reexport contrary to the export control laws and regulations of Japan and/or the country of destination is prohibited.

  Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for further details on these materials or the products contained therein.



# REVISION DESCRIPTION LIST 4250 GROUP DATA SHEET

| Rev.<br>No. | Revision Description | Rev.<br>date |
|-------------|----------------------|--------------|
| 1.0         | First Edition        | 971130       |
| 1.0         | That Edition         | 371100       |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |
|             |                      |              |